我真的搞不清楚你到底想问什么,而且你有的表述也不准确严谨所以只好把基本的单位先说下。比特(bit)即一个二进制位 例如100011就是6比特字节(byte)这是计算机中数据类型最基本的单位了,8bit 组成1byte字(word)两个byte称为一个word,所以字大小应该是16位bit,共两字节双字(double word 简写为DWORD)见名知意,两个字,四个字节,32bit在C语言中,每种数据类型都有其存储长度。而且在特定的平台和特定的编译器下是不一样的。由于WIN32平台用的很多,使用visual studio来做C程序的也有很多(我就是使用visual studio 6.0来学习C语言的),所以我说下这种情况(在Visual C++ 2005 中的)。char 字符型 占1byte 即8位,一个char型数据(例如:a、#、!之类的)用了1个字节来存储unsigned char 无符号的字符型 占1byte 即8位 它主要是为了能够兼容扩展ASCII码,由于 char 由8位表示表示范围为 -128 - +127,无法表示带上扩展ASCII码总共256个字符所以如果把 8位中的最高位符号位也用来计数,就可以正好表示256个字符,unsigned char 表示范围为 0 - 255 正好256个数可以对应包含扩展ASCII码在内的共计256个ASCII字符汉字在计算机中存储是使用机内码(一种数字编号)来存储的,而常用汉字不过是几万个,如果用16位比特(即2的16此方等于65536)就可以表示了,所以汉字字符存储使用了两个字节。每两个字节即16bit对应一个汉字。int 整型数据 占4byte 即32位,一个int型数据的长度用了4个字节来存储short 短整型 占2byte 即16位,两个字节。long 长整型 占4byte 即32为,四个字节float 单精度浮点型 占4byte 即32位,四个字节double 双精度浮点型 占8byte 即64位,八个字节假如你使用的不是 visual studio 编译器 或者不是在win32环境下编程,以上的陈述可能就不对,我建议你查看一下 可以使用int i = sizeof(char)或者sizeof(int)来看看i的值,如果i == 4,表示一个当前的数据类型占四个字节