贝利信息

C++ size_t和int区别 C++无符号与有符号索引类型选择【建议】

日期:2026-01-25 00:00 / 作者:尼克
size_t 是C++标准定义的无符号整型,专用于表示对象大小和数组索引,底层类型平台相关;不能直接当int用,因其无符号性导致与有符号数混用时引发隐式转换、回绕及未定义行为。

size_t 是什么,为什么不能直接当 int 用

size_t 是 C++ 标准定义的无符号整数类型,专门用于表示对象大小或数组索引,其底层实际类型取决于平台(通常是 unsigned longunsigned long long),保证能容纳系统最大可能的内存尺寸。它和 int 的根本区别不在“大小”,而在“符号性”和“语义”:int 是有符号、通用计算类型;size_t 是无符号、专用于尺寸/计数/偏移场景。

常见错误现象:for (int i = container.size() - 1; i >= 0; i--) 在空容器时触发未定义行为——因为 container.size() 返回 size_t,减 1 后变成极大正数(如 18446744073709551615),再与有符号 i 比较,发生隐式转换,循环永远不退出。

什么时候必须用 size_t

所有涉及内存布局、容器尺寸、字节偏移的场景,编译器和标准库强制要求使用 size_t。典型包括:

什么时候可以/应该用 int 或 ptrdiff_t

当你需要表达“差值”“偏移量”“带方向的索引”时,int 不合适,但 ptrdiff_t(指针差值类型)更准确;而简单循环计数若确定范围小且不跨平台,int 可读性更高,但需主动规避无符号回绕风险。

混合运算时的隐式转换陷阱

无符号和有符号整数混用会触发 C++ 的整型提升规则,常导致静默错误。例如:size_t a = 5; int b = -1; if (a > b) 中,b 被提升为 size_t,变成极大正数,条件恒为假。

真正难的不是记住哪个该用,而是意识到「索引是否可能为负」「尺寸是否可能超过 2GB」「这段代码会不会在 32 位嵌入式环境跑」——这些上下文决定了类型选择,而不是语法习惯。