C的整形变量在Turbo C、VC++、Linux下的大小
C语言中,整形变量在不同的编译环境下,其内存分配的大小是不相同的。ANSI C的标准没有规定标识符的长度,但各个C编译系统都有自己的规定。
在C里的整形变量:short、int、long,要求short型不长于int型,long型不短于int型。在TC环境下,short和int型被分配2字节(word),即16位(bit),long型是4字节,即32位。而在其它编译环境下int可能会被分配4字节,与long型相同。
如下是各个编译环境下为三种整形变量所分配的内存空间:
在Turbo C2.0:int 16、short 16、long 32;
在VC++ 6.0: int 32、short 16、long 32;
在Linux下: int 32、short 16、long 32;
为了验证自己所用的编译器为三种整形分配多大的内存空间,可以在当前编译环境下,写一段测试程序来测量它们的实际大小。
/*
查看C中的变量类型(int、short、long等)在Turbo C 里的大小。(方法一)
*/
#include "stdio.h" int main() { /*定义三种整形变量,为int、short的第16位负值1,long的第32位负1,其它位为0*/ unsigned int n_int=0x8000; /*n_int是int型变量*/ unsigned short n_short=0x8000; /*n_int是short型变量*/ unsigned long n_long=0x80000000; /*n_int是long型变量*/ unsigned size_int=16,size_short=16,size_long=32; /*假设int、short型最小16位,long型最小是32位*/ while(1) /*默认死循环*/ { n_int<<=1; /*n_int先左移一位*/ if(n_int!=0) size_int++; /*n_int不为0,说明原先16位的1没有溢出, n_int还有更高位*/ else break; /*n_int为0,说明最高位1溢出,退出死循环*/ } while(1) /*同上*/ { n_short<<=1; if(n_short!=0) size_short++; else break; } while(1) /*同上*/ { n_long<<=1; if(n_long!=0) size_long++; else break; } /*打印出三种类型变量所占内存的大小*/ printf("In This Suite :\n size_int = %d\n size_short = %d\n size_long = %d\n",size_int,size_short,size_long); } 在Turbo C下,运行结果: size_int = 16 size_short = 16 size_long = 32 在VC++_6.0下,运行结果: size_int = 16 size_short = 32 size_long = 32 在Linux_redhat下,运行结果: size_int = 16 size_short = 32 size_long = 32
由此可见,在不同编译环境下,为三种整形变量分配的字节数量不同,了解这些可以防止数据意外溢出,而导致错误,但这种错误通常编译器是不会报错的,这就形成透明错误,看不到但确实存在。
测试数据类型大小的方法很多,也可以用下面的方法:
/*
查看C中的变量类型(int、short、long等)在Turbo C 里的大小。(方法二)
*/
#include "stdio.h" int main() { unsigned int n_int; unsigned short n_short; unsigned long n_long; printf("In This Suite :\n num_int = %d\n num_short = %d\n num_long = %d\n",8*sizeof(n_int),8*sizeof(n_short),8*sizeof(n_long)); return 0; }
这种方法比较简便,利用sizeof函数来帮你查出整形变量的大小,但需要注意sizeof函数返回的是字节数,需要乘以8来修正(一个字节占8位)。