Linux下sizeof运算符的常见误区有哪些

avatar
作者
猴君
阅读量:0

在 Linux 下,sizeof 是一个编译时运算符,用于计算数据类型或对象所占用的内存字节数

  1. 对指针使用 sizeof:当对指针使用 sizeof 时,通常返回指针本身(而非指向的数据类型)所占用的大小。这可能导致错误的结果,因为指针大小与其指向的数据类型大小不同。例如,在 64 位系统上,所有类型的指针大小都是 8 字节。

    int arr[] = {1, 2, 3}; int *ptr = arr; sizeof(ptr); // 返回指针大小,而非整个数组大小 
  2. 对动态分配的内存使用 sizeofsizeof 只能测量静态分配的内存大小。对于动态分配的内存(如使用 malloccalloc 分配的内存),sizeof 无法返回实际分配的内存大小。

    int *arr = (int *) malloc(10 * sizeof(int)); sizeof(arr); // 返回指针大小,而非实际分配的内存大小 
  3. 对空指针使用 sizeof:对空指针使用 sizeof 不会引发错误,但可能导致意外的结果。空指针本身具有特定的大小,通常与其基础类型相同。

    int *ptr = NULL; sizeof(ptr); // 返回指针大小,而非 0 或错误 
  4. 对函数使用 sizeof:在 C 语言中,sizeof 不能直接应用于函数。尝试这样做将导致编译错误。

    int func(int x) {     return x * 2; } sizeof(func); // 编译错误 
  5. 对字符串字面量使用 sizeof:对字符串字面量使用 sizeof 时,它将包括字符串的结尾空字符(\0)。

    sizeof("hello"); // 返回 6,因为包括结尾空字符 

要避免这些误区,请确保在使用 sizeof 时了解其行为和限制。在处理指针和动态分配的内存时,请使用显式的大小变量或其他方法来跟踪内存大小。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!