当前位置: 首页 > news >正文

C 语 言 --- 数 据 类 型 的 存 储

C 语 言 --- 数 据 类 型 的 存 储

  • 空 类 型
  • 大 小 端 存 储
    • 大 端 存 储 --- 正 着 放(从 小 到 大)
    • 小 端 存 储 --- 倒 着 放(从 大 到 小)
  • 浮 点 型 在 内 存 中 的 存 储
  • 总结

💻作 者 简 介:曾 与 你 一 样 迷 茫,现 以 经 验 助 你 入 门 C 语 言
💡个 人 主 页:@笑 口 常 开 xpr 的 个 人 主 页
📚系 列 专 栏:C 启 新 程
✨代 码 趣 语:世 上 只 有 两 种 编 程 语 言:一 种 是 总 是 被 人 骂 的,一 种 是 从 来 没 人 用 的。
💪代 码 千 行,始 于 坚 持,每 日 敲 码,进 阶 编 程 之 路。
📦gitee 链 接:gitee

在这里插入图片描述

       在 编 程 的 世 界 里,每 一 行 代 码 都 可 能 隐 藏 着 无 限 的 可 能 性 。你 是 否 想 过,一 个 小 小 的 程 序 究 竟 能 改 变 什 么?它 可 以 是 解 决 复 杂 问 题 的 工 具 ,也 可 以 是 实 现 梦 想 的 桥 梁。今 天,就 让 我 们 一 起 走 进 C 语 言 数 据 类 型 的 世 界,探 索 它 的 无 限 潜 力。

空 类 型

定 义

在 C 语 言 里,空 类 型 即 void 类 型,它 代 表 “ 无 类 型 ” 或 者 “ 空 类 型 ”。通 常 应 用 于 函 数 的 返 回 类 型、函 数 的 参 数、指 针 类 型。

void 作 为 函 数 返 回 类 型

当 函 数 不 需 要 返 回 值 时,可 将 其 返 回 类 型 声 明 为 void。这 表 明 该 函 数 执 行 特 定 操 作,不 会 返 回 任 何 数 据。

下 面 展 示代 码 示 例

#include <stdio.h>
#define ROW 10
void sort(int arr[ROW],int sz)
{int i = 0;for (i = 0;i < sz - 1;i++){int j = 0;for (j = 0;j < sz - 1 - i;j++){if (arr[j] < arr[j + 1]){int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}
}
int main() 
{int arr[ROW] = { 1,2,3,4,5,6,7,8,9,10 };int sz = sizeof(arr) / sizeof(arr[0]);sort(arr, sz);int i = 0;for (i = 0;i < sz;i++){printf("%d ", arr[i]);}printf("\n");return 0;
}

在这里插入图片描述

void 作 为 函 数 参 数

如 果 函 数 不 接 受 任 何 参 数,可 在 函 数 声 明 和 定 义 时 使 用 void。不 过 在 C 语 言 里,空 的 参 数 列 表 ( ) 也 表 示 函 数 不 接 受 参 数。

下 面 展 示代 码 示 例

#include <stdio.h>
//定义一个不接受参数的函数
void print(void) 
{printf("Hello World!\n");
}
int main() 
{print();return 0;
}

在这里插入图片描述

void 指 针

void 指 针 是 一 种 特 殊 类 型 的 指 针,它 可 以 指 向 任 意 类 型 的 数 据。void 指 针 没 有 具 体 的 数 据 类 型,因 此 在 使 用 时 需 要 进 行 显 式 的 类 型 转 换,即 强 制 类 型 转 换,否 则 程 序 会 报 错。

下 面 展 示代 码 示 例

#include <stdio.h>
int main() 
{int num = 10;char ch = 'A';//定义一个void指针,并指向int类型的数据void* ptr = &num;//显式类型转换int* intPtr = (int*)ptr;printf("通过void指针访问int类型数据:%d\n", *intPtr);ptr = &ch;// 显式类型转换char* charPtr = (char*)ptr;printf("通过void指针访问char类型数据:%c\n", *charPtr);return 0;
}

在这里插入图片描述

大 小 端 存 储

定 义

在 计 算 机 中,数 据 通 常 以 字 节 为 单 位 进 行 存 储,每 个 字 节 都 有 对 应 的 内 存 地 址。对 于 多 字 节 数 据( 如 整 数、浮 点 数 ),就 存 在 字 节 顺 序 的 问 题,而 大 小 端 存 储 模 式 就 是 用 来 描 述 多 字 节 数 据 在 内 存 中 字 节 排 列 顺 序 的 方 式。

大 端 存 储 — 正 着 放(从 小 到 大)

定 义

大 端 存 储,也 称 为 大 端 字 节 序 存 储,是 指 将 数 据 的 高 位 字 节 存 于 低 地 址,低 位 字 节 存 于 高 地 址。这 与 我 们 日 常 书 写 数 字 的 习 惯 相 符。

举 例

有 一 个 4 字 节 的 整 数 0x12345678。在 大 端 存 储 模 式 下,内 存 中 的 存 储 顺 序 如 下:

在这里插入图片描述

小 端 存 储 — 倒 着 放(从 大 到 小)

定 义

小 端 存 储,也 称 为 小 端 字 节 序 存 储,是 指 将 数 据 的 低 位 字 节 存 于 低 地 址,高 位 字 节 存 于 高 地 址。

举 例

同 样 以 4 字 节 的 整 数 0x12345678 为 例,在 小 端 存 储 模 式 下,内 存 中 的 存 储 顺 序 如 下:

在这里插入图片描述

设 计 一 段 代 码 来 验 证 当 前 环 境 的 字 节 序 ( 大 小 端 )

温 馨 提 示:读 者 们 ,先 自 己 计 算 答 案,这 是 提 升 编 程 能 力 的 好 机 会。若 未 达 要 求 ,别 气 馁 ,参 考 下 文 解 释 会 有 新 收 获。

方 法 一

下 面 展 示代 码 示 例

#include <stdio.h>
int check_sys()
{int i = 1;char* pa = (char*)&i;if (*pa)//取出i的地址,强制转换成char*,后解引用{return 1;}else{return 0;}
}
int main()
{int ret = check_sys();if (ret == 1){printf("小端\n");}else{printf("大端\n");}return 0;
}

在这里插入图片描述

方 法 二

下 面 展 示代 码 示 例

#include <stdio.h>
int check_sys()
{int i = 1;if (*(char*)&i)//取出i的地址,强制转换成char*,后解引用{return 1;}else{return 0;}
}
int main()
{int ret = check_sys();if (ret == 1){printf("小端\n");}else{printf("大端\n");}return 0;
}

在这里插入图片描述

方 法 三

下 面 展 示代 码 示 例

#include <stdio.h>
int check_sys()
{int i = 1;return *(char*)&i;//取出i的地址,强制转换成char*,后解引用
}
int main()
{int ret = check_sys();if (ret == 1){printf("小端\n");}else{printf("大端\n");}return 0;
}

在这里插入图片描述

浮 点 型 在 内 存 中 的 存 储

定 义

在 C 语 言 里,浮 点 型 数 据 主 要 包 含 float(单 精 度 浮 点 数)和 double(双 精 度 浮 点 数)两 种 类 型。它 们 在 内 存 中 的 存 储 遵 循 IEEE754 标准。

IEEE754标 准

定 义

IEEE 754 标 准 采 用 一 种 特 定 的 格 式 来 表 示 浮 点 数,这 个 格 式 由 三 个 部 分 构 成:符 号 位(Sign)、指 数 位(Exponent)和 尾 数 位 (Mantissa)。

符 号 位(S):该 位 用 来 表 示 浮 点 数 的 正 负,0 代 表 正 数,1 代 表 负 数。

指 数 位(E):指 数 位 表 示 浮 点 数 的 指 数 部 分,采 用 偏 移 量 的方 式 存 储。

尾 数 位(M):尾 数 位 表 示 浮 点 数 的 小 数 部 分,也 被 称 作 有 效 数 字,M 大 于 等 于 1,小 于 2。

格 式

(-1) ^ S * M * 2 ^ E

32 位 的 浮 点 数,最 高 的 1 位 是 符 号 位 s,接 着 的 8 位 是 指 数 E,剩 下 的 23 位 为 有 效 数 字 M。

在这里插入图片描述

64 位 的 浮 点 数,最 高 的 1 位 是 符 号 位 S,接 着 的 11 位 是 指 数 E,剩 下 的 52 位 为 有 效 数 字 M。

在这里插入图片描述

特 别 规 定

M

1 ≤ M < 2,也 就 是 说,M 可 以 写 成 1.xxxxxx 的 形 式,其 中 xxxxxx 表 示 小 数 部 分。在 计 算 机 内 部 保 存 M 时,默 认 这 个 数 的 第 一 位 总 是 1,因 此 可 以 被 舍 去,只 保 存 后 面 的 xxxxxx 部 分。比 如 保 存 1.01 的 时 候,只 保 存 01,等 到 读 取 的 时 候,再 把 第 一 位 的 1 加 上 去。这 样 做 的 目 的,是 节 省 1 位 有 效 数 字。以 32 位 浮 点 数 为 例,留 给 M 只 有 23 位,将 第 一 位 的 1 舍 去 以 后,等 于 可 以 保 存 24 位 有 效 数 字。

E

在 IEEE754 标 准 里,指 数 位 E 是 一 个 无 符 号 整 数。若 E 占 8 位,其 取 值 范 围 是 0 到 255;若 E 占 11 位,取 值 范 围 则 是 0 到 2047。然 而,科 学 计 数 法 中 的 指 数 E 是 可 以 为 负 数 的。在 将 E 存 入 内 存 时,需 给 其 真 实 值 加 上 一 个 中 间 数。对 于 8 位 的 E,这 个 中 间 数 是 127;对 于 11 位 的 E,中 间 数 是 1023。例 如,对 于 数 值 2 ^ 10,其 指 数 E 的 真 实 值 为 10,当 把 它 保 存 为 32 位 浮 点 数 时,E 的 值 要 保 存 为 10 + 127 = 137,对 应 的 二 进 制 表 示 为 10001001。

指 数 E 从 内 存 中 取 出

E 不 全 为 0 或 不 全 为 1

浮 点 数 就 采 用 下 面 的 规 则 表 示,即 指 数 E 的 计 算 值 减 去 127(或1023),得 到 真 实 值,再 将 有 效 数 字 M 前 加 上 第 一 位 的 1。比 如:0.5 的 二 进 制 形 式 为 0.1,由 于 规 定 正 数 部 分 必 须 为 1,即 将 小 数 点 右 移 1 位,则 为 1.0 * 2 ^ (-1),其 阶 码 为 -1 + 127 = 126,表 示 为 01111110,而 尾 数 1.0 去 掉 整 数 部 分 为 0,补 齐 0 到 23 位 00000000000000000000000,则 其 二 进 制 表 示 形 式 为 :
0 01111110 00000000000000000000000
E 全 为 0

浮 点 数 的 指 数 E 等 于 1 - 127( 或 者 1 - 1023 )即 为 真 实 值,有 效 数字 M 不 再 加 上 第 一 位 的 1,而 是 还 原 为 0.xxxxxx 的 小 数。这 样 做 是 为 了 表 示 ±0,以 及 接 近 于 0 的 很 小 的 数 字。

E 全 为 1

如 果 有 效 数 字 M 全 为 0,表 示 ± 无 穷 大( 正 负 取 决 于 符 号 位 s )

下 面 展 示代 码 示 例

#include<stdio.h>
int main()
{float f = 5.5f;//101.1//(1.011) * 2 ^ 2	--- 类似十进制//(-1) ^ 0 * 1.011 * 2 ^ 2 --- (-1) ^ S * M * 2 ^ E//s = 0,M = 1.011,E = 2//0 10000001 01100000000000000000000//0100 0000 1011 0000 0000 0000 0000 0000//40 b0 00 00return 0;
}

在这里插入图片描述

这 里 采 用 小 端 存 储 模 式,所 以 在 内 存 中 浮 点 数 是 倒 着 放 的。

下 面 展 示代 码 示 例

温 馨 提 示:读 者 们 ,先 自 己 计 算 答 案,这 是 提 升 编 程 能 力 的 好 机 会。若 未 达 要 求 ,别 气 馁 ,参 考 下 文 解 释 会 有 新 收 获。

#include<stdio.h>
int main()
{int n = 9;float* pFloat = (float*)&n;printf("n的值为:%d\n", n);printf("*pFloat的值为:%f\n", *pFloat);*pFloat = 9.0;printf("n的值为:%d\n", n);printf("*pFloat的值为:%f\n", *pFloat);return 0;
}

在这里插入图片描述

下 面 展 示解 析

#include<stdio.h>
int main()
{int n = 9;float* pFloat = (float*)&n;printf("n的值为:%d\n", n);//00000000000000000000000000001001//0 00000000 00000000000000000001001//(-1) ^ 0 * 0.00000000000000000001001 * 2 ^ -126//E是一个很小的接近于0的正数,所以用十进制小数表示就是0.000000。printf("*pFloat的值为:%f\n", *pFloat);*pFloat = 9.0;//1001.0 * 2 ^ 3//(-1) ^ 0 * 1.001 * 2 ^ 3//s = 0//e = 3//m = 1.001//0 10000010 00100000000000000000000printf("n的值为:%d\n", n);//0100 0001 0001 0000 0000 0000 0000 0000//41 10 00 00printf("*pFloat的值为:%f\n", *pFloat);return 0;
}

在这里插入图片描述
在这里插入图片描述

总结

       至 此,关 于 C 语 言 数 据 类 型 的 存 储 的 探 索 暂 告 一 段 落,但 你 的 编 程 征 程 才 刚 刚 启 航。写 代 码 是 与 机 器 深 度 对 话,过 程 中 虽 会 在 语 法、算 法 困 境 里 挣 扎,但 这 些 磨 砺 加 深 了 对 代 码 的 理 解。愿 你 合 上 电 脑 后,灵 感 不 断,在 C 语 言 的 世 界 里 持 续 深 耕,书 写 属 于 自 己 的 编 程 传 奇,下 一 次 开 启 ,定 有 全 新 的 精 彩 等 待。小 编 期 待 重 逢,盼 下 次 阅 读 见 你 们 更 大 进 步,共 赴 代 码 之 约!

相关文章:

C 语 言 --- 数 据 类 型 的 存 储

C 语 言 --- 数 据 类 型 的 存 储 空 类 型大 小 端 存 储大 端 存 储 --- 正 着 放&#xff08;从 小 到 大&#xff09;小 端 存 储 --- 倒 着 放&#xff08;从 大 到 小&#xff09; 浮 点 型 在 内 存 中 的 存 储总结 &#x1f4bb;作 者 简 介&#xff1a;曾 与 你 一 …...

3.8 字符串的常用函数

重点&#xff1a;字符串的常用函数 #1.测试转换大小写 lower:大写->小写 upper&#xff1a;小写->大写 swapcase&#xff1a;自动将大写转小写小写转大写 print("ABC".lower()) #abcprint("abc".upper()) #ABCprint…...

事件触发控制与响应驱动控制的定义、种类及区别

一、定义 事件触发控制&#xff08;Event-Triggered Control, ETC&#xff09; 事件触发控制是一种基于动态条件触发的控制策略&#xff0c;其核心在于通过预设的事件触发条件&#xff08;如系统状态误差超过阈值、特定信号到达等&#xff09;来决定何时更新控制信号或进行通信…...

Android离屏渲染

写在前面 与iOS同事聊天时聊到圆角会使用离屏渲染的方式绘制&#xff0c;影响性能&#xff1b;Android上有没有不知道&#xff0c;学习了一下整理了这篇文章。 Android 圆角与离屏渲染&#xff08;Offscreen Rendering&#xff09; 一、什么是离屏渲染&#xff1f; 离屏渲染…...

35. 搜索插入位置

给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5 输出: 2示例 2: 输入:…...

网络的起点:深入解析计算机网络中的网络接口层

一、什么是网络接口层&#xff1f; 计算机网络的 网络接口层&#xff08;Network Interface Layer&#xff09;&#xff0c;在 TCP/IP模型 中处于最底层&#xff0c;负责将数据从计算机传输到物理网络媒介&#xff0c;并在此基础上确保数据的正确传输。它位于数据链路层和物理…...

智能指针(内存泄漏)

一、RALL RALL的核心概念&#xff1a; 资源获取即初始化&#xff1a;资源的分配与对象的初始化绑定在一起&#xff0c;资源的释放与对象的销毁绑定在一起。 不是所有智能指针都用这个思想 可以有效避免死锁问题 二、智能指针 通过将new出的对象教给有生命周期的对象处理。 在…...

秒杀秒抢系统开发:飞算 JavaAI 工具如何应对高并发难题?

秒杀、秒抢活动已成为电商促销与吸引流量的常用手段。然而&#xff0c;此类活动所带来的高并发访问&#xff0c;对系统性能构成了巨大挑战。如何确保系统在高并发场景下依然能够稳定、高效运行&#xff0c;成为开发者亟待解决的关键问题。飞算 JavaAI 工具作为一款功能强大的开…...

AI在代码Review中的应用试验与推广策略

一、引言 在软件开发领域&#xff0c;代码审查&#xff08;Code Review&#xff09;是保障代码质量的关键环节。传统的代码审查依赖人工&#xff0c;不仅效率低下&#xff0c;而且容易出现疏漏。随着人工智能技术的发展&#xff0c;AI在代码审查中的应用逐渐成为可能。近期&am…...

自定义Jackson序列化和反序列化

为什么需要自定义Jackson序列化和反序列化?下面举个例子看看就知道了 问题描述 由于 Spring Boot 内置使用的就是 Jackson JSON 框架&#xff0c;所以&#xff0c;无需引入新的依赖&#xff0c;仅需添加自定义配置类即可&#xff0c;让其支持新的日期 API Controller层的代码…...

人工智能浪潮与生成式人工智能认证(GAI认证)的登场

当ChatGPT在2023年引爆全球对话时,人类已悄然站在人工智能发展史上的关键转折点。生成式人工智能(Generative AI)不再仅仅是实验室中的技术概念,而是正在重塑内容创作、商业决策、教育医疗等领域的底层逻辑。这场技术浪潮的冲击力,不仅体现在算法模型的指数级进化上,更在…...

Redis - 讲清楚集群模式(Redis Cluster)(上)

节点与集群构建 节点组成&#xff1a;Redis集群由多个独立节点组成&#xff0c;通过CLUSTER MEET命令实现节点握手&#xff0c;形成集群。 握手过程&#xff1a; 节点A为节点B创建clusterNode结构&#xff0c;发送MEET消息。 节点B接收后创建节点A的clusterNode结构&#xff…...

什么是 矩阵号 ?为什么要做海外矩阵?

简单说&#xff0c;就是——在海外平台批量搞账号/店铺&#xff0c;组团赚钱&#xff01; 比如这样玩&#x1f447; ● TikTok 矩阵号&#xff1a;5 个账号&#xff0c;分别做美妆、3C、家居&#xff0c;覆盖不同老外兴趣圈。 ● 亚马逊矩阵店铺&#xff1a;A 店卖手机壳&#…...

10 穴 汽车连接器的15个设计特点

汽车行业严重依赖卓越的电气系统来确保功能和可靠性。这些系统的关键组件是 10 腔连接器&#xff0c;它为布线和信号传输提供解决方案。制造商和工程师必须仔细评估这些连接器的设计特性&#xff0c;以优化性能和安全性。 本博客研究了汽车 10 腔连接器的 15 个设计特征&#…...

WHAT - 动态导入模块遇到版本更新解决方案

文章目录 一、动态导入模块二、常见原因与解决方案1. 模块 URL 错误2. 开发人员发版用户停留在旧页面问题背景解决方案思路1. 监听错误&#xff0c;提示用户刷新2. 使用缓存控制策略&#xff1a;强制刷新3. 动态模块加载失败时兜底4. 使用 import.meta.glob() 或 webpack 的 __…...

4.15学习总结

学习了IO流和相关的字符集 完成一道算法题...

THCON 2025

Crypto OTPas_ouf 用10个字符异或加密的jpg图片&#xff0c;通过头得到key再恢复原图 Mammoths Personnal Slot Machine 梅森旋转恢复 from pwn import * from randcrack import RandCrack from tqdm import trange context.log_level errorp remote(74.234.198.209, 33…...

Linux 深入浅出信号量:从线程到进程的同步与互斥实战指南

知识点1【信号量概述】 信号量是广泛用于进程和线程间的同步和互斥。信号量的本质 是一个非负的整数计数器&#xff0c;它被用来控制对公共资源的访问 当信号量值大于0的时候&#xff0c;可以访问&#xff0c;否则将阻塞。 PV原语对信号量的操作&#xff0c;一次P操作使信号…...

github配置ssh,全程CV

1)随便找一个文件夹右键进入git bash 2)验证是否已有公私钥文件 cd ~/.ssh ls如果不存在则生成然后获取 生成时一直回车 ssh-keygen -t rsa -C "xxxxxx.com" cd ~/.ssh cat id_rsa.pub如果存在则直接获取 cd ~/.ssh cat id_rsa.pub3&#xff09;复制 4&#xf…...

MySQL——存储

一、什么是存储过程 存储过程&#xff08;Stored Procedure&#xff09; 是预编译并存储在数据库中的一段SQL代码集合&#xff0c;支持参数传递、流程控制和返回值。通过类似“方法调用”的方式执行&#xff0c;存储过程将复杂业务逻辑封装在数据库层&#xff0c;简化应用开发…...

matlab中进行海浪模型仿真

matlab中进行海浪模型仿真&#xff0c;采用优化处理算法&#xff0c;进行防止干扰的海浪算法设计 BarhPlot.m , 180 wave.m , 1649...

边缘计算与隐私计算的融合:构建数据经济的“隐形护盾“

在数据成为核心生产要素的今天&#xff0c;边缘计算与隐私计算的交汇正在重塑技术生态。这并非简单的技术叠加&#xff0c;而是一场关于数据主权、算力分配与信任机制的深度博弈。本文将从"数据流动的拓扑学"视角&#xff0c;探讨二者融合如何重构数字社会的基础设施…...

实现表单验证

给Form.ITem组件绑定 name和rules字段 #增加表单验证的触发事件 失焦 onblur 添加多条验证逻辑 串行验证逻辑 实现表单提交验证 获得的值的属性名由form组件中的name属性决定 如果表单验证通过自动触发属性onFinish绑定的回调函数获得提交内容 封装request模块...

图论-BFS搜索图/树-最短路径问题的解决

续上篇~图论--DFS搜索图/树-CSDN博客 先看第一次学习的博客&#xff01;&#xff01;&#x1f447;&#x1f447;&#x1f447;&#x1f447; &#x1f449; 有一些问题是广搜 和 深搜都可以解决的&#xff0c;例如岛屿问题&#xff0c;这里我们记dfs的写法就好啦&#xff0c;…...

大数据学习(107)-sql中case使用场景

&#x1f34b;&#x1f34b;大数据学习&#x1f34b;&#x1f34b; &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 用力所能及&#xff0c;改变世界。 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一…...

数据战略新范式:从中台沉淀到服务觉醒,SQL2API 如何重塑数据价值链条?

一、数据中台退烧&#xff1a;从 “战略神话” 到 “现实拷问” 曾几何时&#xff0c;数据中台被视为企业数字化转型的 “万能解药”&#xff0c;承载着统一数据资产、打破业务壁垒的厚望。然而&#xff0c;大量实践暴露出其固有缺陷&#xff1a;某零售企业投入 500 万元建设中…...

MyBatis SqlSessionFactory 批量执行实战

在 MyBatis 中&#xff0c;批量操作是处理高并发数据写入的核心场景之一。通过 SqlSessionFactory 配置批处理执行器&#xff08;ExecutorType.BATCH&#xff09;&#xff0c;可以显著提升数据库操作的效率。本文将结合 Spring 框架&#xff0c;深入解析如何高效配置和使用 MyB…...

【初阶数据结构】——算法复杂度

一、前言 1、数据结构是什么&#xff1f; 数据结构(Data Structure)是计算机存储、组织数据的⽅式&#xff0c;指相互之间存在⼀种或多种特定关系的数 据元素的集合。没有⼀种单⼀的数据结构对所有⽤途都有⽤&#xff0c;所以我们要学各式各样的数据结构&#xff0c; 如&…...

Oracle数据库数据编程SQL<00. 课外关注:rownum、rowid、level、row_number 对比详解与实战>

更多Oracle学习内容请查看&#xff1a;Oracle保姆级超详细系列教程_Tyler先森的博客-CSDN博客 目录 一、基本概念与区别 二、ROWNUM 详解与实战 1. 基本特性 2. 典型应用 2.1 分页查询&#xff08;Oracle传统方式&#xff09; 2.2 限制返回行数 2.3 随机抽样 3. 注意事…...

凸优化基础

文章目录 目录**第1讲&#xff1a;凸优化基础****第2讲&#xff1a;凸优化建模****第3讲&#xff1a;对偶理论****第4讲&#xff1a;梯度下降法****第5讲&#xff1a;牛顿法与内点法****第6讲&#xff1a;次梯度与近端方法****第7讲&#xff1a;分布式凸优化****第8讲&#xff…...

LeetCode面试热题150中12-18题学习笔记(用Java语言描述)

Day 03 12、 O ( 1 ) O(1) O(1)时间插入、删除元素和获取元素 需求&#xff1a;实现RandomizedSet 类&#xff1a; RandomizedSet() 初始化 RandomizedSet 对象bool insert(int val) 当元素 val 不存在时&#xff0c;向集合中插入该项&#xff0c;并返回 true &#xff1b;否…...

开源模型集成接口

一、OpenRouter 概述 ‌ OpenRouter‌是一个开源的大模型API路由器&#xff0c;旨在将各种AI模型和服务集成到一个统一的接口中&#xff0c;使用户能够通过简单的配置调用不同大模型的能力‌。其主要功能包括智能路由用户请求到不同的AI模型&#xff0c;并提供统一的访问接…...

python成功解决AttributeError: can‘t set attribute ‘lines‘

文章目录 报错信息与原因分析解决方法示例代码代码解释总结 报错信息与原因分析 在使用 matplotlib绘图时&#xff0c;若尝试使用 ax.lines []来清除图表中的线条&#xff0c;会遇到AttributeError: can’t set attribute错误。这是因为 ax.lines是一个只读属性&#xff0c;不…...

宿舍管理系统(servlet+jsp)

宿舍管理系统(servletjsp) 宿舍管理系统是一个用于管理学生宿舍信息的平台&#xff0c;支持超级管理员、教师端和学生端三种用户角色登录。系统功能包括宿舍管理员管理、学生管理、宿舍楼管理、缺勤记录、添加宿舍房间、心理咨询留言板、修改密码和退出系统等模块。宿舍管理员…...

Unity UI 从零到精通 (第30天): Canvas、布局与C#交互实战

Langchain系列文章目录 01-玩转LangChain&#xff1a;从模型调用到Prompt模板与输出解析的完整指南 02-玩转 LangChain Memory 模块&#xff1a;四种记忆类型详解及应用场景全覆盖 03-全面掌握 LangChain&#xff1a;从核心链条构建到动态任务分配的实战指南 04-玩转 LangChai…...

vue项目打包部署到maven仓库

需要的资源文件&#xff0c;都放在根目录下&#xff1a; 1. versionInfo.js const fs require(fs) const path require(path) const mkdirp require(mkdirp) const spawn require(child_process).spawnconst packageObj require(./package.json) const versionNo packa…...

【力扣】day1

文章目录 27.移除元素26. 删除有序数组的重复项 27.移除元素 26. 删除有序数组的重复项 我们仔细看一下这两道题的最后的返回值,为什么第一题返回slow 而第二题返回slow1 最后的返回值该如何返回绝对不是凭感觉,我们自己分析一下第一个slow,从0位置开始, 遇到val值就开始和fas…...

MySQL:B+树索引

InnoDB索引方案 为了使用二分法快速定位具体的目录项&#xff0c;假设所有目录项都可以在物理存储器上连续存储&#xff0c;有以下问题&#xff1a; InnoDB使用页为管理存储空间的基本单位&#xff0c;最多只能保证16KB的连续存储空间&#xff0c;记录数据量多可能需要非常大…...

如何建立可复用的项目管理模板

建立可复用的项目管理模板能够显著提高项目执行效率、减少重复劳动、确保项目管理标准化。在企业中&#xff0c;项目管理往往涉及多个步骤和多个团队&#xff0c;然而每次开始一个新项目时&#xff0c;如果都从头开始设计流程和文档&#xff0c;势必浪费大量的时间和精力。通过…...

Go:goroutine 和通道

goroutine f() // 等待 f() 返回 go f() // 新建一个调用 f() 的 goroutine&#xff0c;不用等待在 Go 语言里&#xff0c;goroutine 是并发执行的活动单元。与顺序执行程序不同&#xff0c;在有多个 goroutine 的并发程序中&#xff0c;不同函数可同时执行。程序启动时&…...

盛水最多的容器问题详解:双指针法与暴力法的对比与实现

文章目录 问题描述方法探讨方法一&#xff1a;暴力法&#xff08;Brute Force&#xff09;思路代码实现复杂度分析 方法二&#xff1a;双指针法&#xff08;Two Pointers&#xff09;思路正确性证明代码实现复杂度分析 方法对比总结 摘要 盛水最多的容器&#xff08;Container …...

VMWare 16 PRO 安装 Rocky8 并部署 MySQL8

VMWare 16 PRO 安装 Rocky8 并部署 MySQL8 一.Rocky OS 下载1.官网 二.配置 Rocky1.创建新的虚拟机2.稍后安装系统3.选择系统模板4.设置名字和位置5.设置大小6.自定义硬件设置核心、运存和系统镜像7.完成 三.启动安装1.上下键直接选择安装2.回车安装3.设置分区&#xff08;默认…...

日常学习开发记录-slider组件

日常学习开发记录-slider组件 从零开始实现一个优雅的Slider滑块组件前言一、基础实现1. 组件结构设计2. 基础样式实现3. 基础交互实现 二、功能增强1. 添加拖动功能2. 支持范围选择3. 添加垂直模式 三、高级特性1. 键盘操作支持2. 禁用状态 五、使用示例六、总结 从零开始实现…...

AIDL 中如何传递 Parcelable 对象

目录 1. 直接在 AIDL 中定义 Parcelable 对象2. 自定义 Parcelable 对象的传递3. 以 Rect 类为例的 Parcelable 实现4. 注意安全性5. 小结1. 直接在 AIDL 中定义 Parcelable 对象 背景说明 从 Android 10(API 级别 29)开始,AIDL 允许直接在 .aidl 文件中定义 Parcelable 对…...

LVGL实战训练——计算器实现

目录 一、简介 二、部件知识 2.1 按钮矩阵部件(lv_btnmatrix) 2.1.1 按钮矩阵部件的组成 2.1.2 按钮文本设置 2.1.3 按钮索引 2.1.4 按钮宽度 2.1.5 按钮属性 2.1.6 按钮互斥 2.1.7 按钮文本重着色 2.1.8 按钮矩阵部件的事件 2.1.9 按钮矩阵部件的 API 函数 2.2…...

代码随想录算法训练营Day30

力扣452.用最少数量的箭引爆气球【medium】 力扣435.无重叠区间【medium】 力扣763.划分字母区间【medium】 力扣56.合并区间【medium】 一、力扣452.用最少数量的箭引爆气球【medium】 题目链接&#xff1a;力扣452.用最少数量的箭引爆气球 视频链接&#xff1a;代码随想录 题…...

AIDL 语言简介

目录 软件包类型注释导入AIDL 的后端AIDL 语言大致上基于 Java 语言。AIDL 文件不仅定义了接口本身,还会定义这个接口中用到的数据类型和常量。 软件包 每个 AIDL 文件都以一个可选软件包开头,该软件包与各个后端中的软件包名称相对应。软件包声明如下所示: package my.pac…...

经典算法 判断一个图中是否有环

判断一个图中是否有环 问题描述 给一个以0 0结尾的整数对列表&#xff0c;除0 0外的每两个整数表示一条连接了这两个节点的边。假设节点编号不超过100000大于0。你只要判断由这些节点和边构成的图中是否存在环。存在输出YES&#xff0c;不存在输出NO。 输入样例1 6 8 5 3 …...

Transformer-PyTorch实战项目——文本分类

Transformer-PyTorch实战项目——文本分类 ———————————————————————————————————————————— 【前言】 这篇文章将带领大家使用Hugging Face里的模型进行微调&#xff0c;并运用在我们自己的新项目——文本分类中。需要大家提前下…...

Linux-服务器负载评估方法

在 Linux 服务器中&#xff0c;top 命令显示的 load average&#xff08;平均负载&#xff09;反映了系统在特定时间段内的负载情况。它通常显示为三个数值&#xff0c;分别代表过去 1 分钟、5 分钟和 15 分钟的平均负载。 1. 什么是 Load Average&#xff1f; Load average …...