C++数据类型是程序设计基石,决定变量存储内容、内存占用及运算方式;整型分有符号与无符号,位宽依平台而异,推荐用int处理一般整数,需确定长度时优先选int32_t等固定宽度类型。

C++ 的数据类型是程序设计的基石,理解它们才能写出安全、高效、可读性强的代码。 它们决定了变量能存什么、占多少内存、怎么参与运算。下面从最常用的基础类型开始,讲清楚本质和用法。
整型:区分有符号与无符号,注意位宽和平台差异
整型用于表示整数,核心区别在于是否支持负数(有符号 vs 无符号)以及占用字节数(影响取值范围)。C++ 标准只规定了最小位宽,实际大小依赖编译器和平台(如 x86_64 下通常 int 是 4 字节,但不绝对)。
-
int / short / long / long long:默认为有符号。推荐优先使用 int 处理一般整数;需要明确长度时,用 int32_t、int64_t(需包含
)更可靠。 - unsigned int 等:只能存 ≥0 的数。做数组下标、容器大小(如 std::vector::size() 返回 size_t,本质是无符号整型)时常见,但混合有/无符号运算易出错(如 if (i 中若 v 为空,size()-1 会绕回极大正数)。
- 避免直接依赖 sizeof(int) 等,用 std::numeric_limits
::max() 查范围(需)。
浮点型:精度与范围并存,慎用于相等判断
浮点数按 IEEE 754 标准存储,存在精度损失,不能精确表示所有小数(如 0.1 在二进制中是无限循环小数)。
- float(约 6–7 位有效数字)、double(约 15–16 位)、long double(平台相关,通常 ≥ double)。
- 永远不要用 == 判断两个浮点数是否相等。应判断差值是否小于一个极小阈值(epsilon),例如:abs(a - b) 。
- 涉及钱、计数等必须精确的场景,改用整数(如“分”代替“元”)或专用库(如 boost::multiprecision)。
字符与布尔型:char 不只是字母,bool 是独立类型
char 本质是 1 字节整数,可参与算术运算(如 'a' + 1 得 'b');bool 只有两个值:true 和 false,底层通常用 1 字节存储,但不是 int 的别名。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~