C++数据类型有哪些 C++基本数据类型内存占用一览表【基础】

8次阅读

c++char、short、int、long、long long等类型大小不固定,仅规定最小位宽和相对大小关系,实际字节数依赖编译器和平台;char恒为1字节,其余类型需用定宽类型或sizeof/numeric_limits验证。

C++数据类型有哪些 C++基本数据类型内存占用一览表【基础】

char、short、int、long、long long 的实际大小不是固定的

C++ 标准只规定了这些类型的**最小位宽**和相对大小关系(比如 sizeof(long) >= sizeof(int)),不强制要求具体字节数。实际大小取决于编译器和目标平台。例如在 windows x64 上用 MSVC,int 是 4 字节;但在某些嵌入式平台,int 可能是 2 字节。

常见误区是认为 int 一定是 4 字节——它只是「通常」是,但不可依赖。需要可移植代码时,优先用 中的定宽类型,比如 int32_tuint8_t

  • char 固定为 1 字节(sizeof(char) == 1 是 C++ 强制保证)
  • short ≥ 16 位,常见为 2 字节
  • int ≥ 16 位,主流平台多为 4 字节
  • long ≥ 32 位,windows x64 是 4 字节,linux x64 是 8 字节
  • long long ≥ 64 位,几乎所有现代平台都是 8 字节

Floatdouble、long double 的精度与内存占用差异大

IEEE 754 是事实标准,但 long double 尤其危险:MSVC 完全忽略它(和 double 等价),GCC 在 x86 上用 80 位扩展精度(10 字节存储,但 sizeof(long double) 常为 12 或 16),而 ARM64 通常直接映射为 64 位 double。

如果你写数值计算,别假设 long double 更精确——先查编译器文档,或直接用 std::numeric_limits::digits10 检查有效十进制位数。

立即学习C++免费学习笔记(深入)”;

  • float:通常 4 字节,约 6–7 位十进制精度
  • double:通常 8 字节,约 15–16 位
  • long double:3 字节起跳,行为高度平台相关,sizeof 不等于实际精度位宽

boolvoid 不是“存储数据”的类型,但各有陷阱

boolsizeof 不是 1 字节就安全——它只是“至少能存 true/false”,实际大小由 ABI 决定(常见为 1 字节,但某些调试模式或结构体对齐下可能被填充成 4 字节)。更关键的是:bool 只有两个合法值:truefalse;用 memcpy 或位操作往 bool* 写非 0/1 值是未定义行为。

void 不能定义变量,但 void* 是万能指针类型;注意它不能算术运算(ptr + 1 非法),也不能解引用。C++17 起禁止 void 作为函数返回值以外的用途(如模板参数)。

  • 不要用 sizeof(bool) 推断内存布局,结构体中它的偏移受对齐规则支配
  • void* 转其他指针必须显式 static_cast,C 风格转换在 C++ 中不推荐
  • void 函数参数列表 () 表示无参数,不是“任意参数”(那是 ...

如何在代码里查清当前平台的真实大小

别靠记忆或教程表格,直接运行 sizeofstd::numeric_limits。尤其当跨平台开发或对接 C API(比如 OpenGL、Win32)时,结构体字段大小错一位,整个二进制协议就崩。

最简验证方式:

#include  #include  int main() {     std::cout << "int: " << sizeof(int) << " bytesn";     std::cout << "double: " << sizeof(double) << " bytesn";     std::cout << "int max: " << std::numeric_limits::max() << "n"; }

记住:同一份源码,在 MSVC、Clang、GCC 下,甚至同一编译器不同架构目标(x86 vs aarch64)下,结果都可能不同。最保险的做法,是在构建脚本里加入 size check 断言,或者用 static_assert(sizeof(int) == 4, "int must be 4 bytes for our protocol")

text=ZqhQzanResources