c语言中的整型
㈠ 你真的了解c语言中的整型吗
在C语言的世界里,整型数据类型是基础且重要的概念。我们通常会遇到用int表示的整数类型,但这只是冰山一角。实际上,C语言提供了多种整型类型,以适应不同的存储需求和数据范围。过去的年代,计算机存储资源有限,所以程序员们会根据数据范围选择最节省空间的类型。
这些类型包括char(1字节)、short(通常2字节)、int(通常4字节)、long(同样4字节或8字节,取决于平台)和long long(8字节)。选择哪种类型,取决于数据预计的使用范围,以及对内存效率的考量。
了解这些类型大小的方法,就是借助sizeof这个关键词。它可以测量数据类型或变量占用的字节数。通过测量,我们可以得知像int在Visual Studio 2019中通常占用4个字节,而更大数据范围的类型占用更多字节。
比如,char占用1字节,能表示0到255的数值;short和int占用2或4字节,分别对应更大的数值范围。对于负数,C语言使用补码表示法,通过最高位区分正负,并巧妙地利用溢出进行计算。
在编写代码时,如果对数据范围有严格要求,可以使用无符号整型(unsigned)来避免负数。而对于字符类型(char),它最初是为拉丁字符设计的,占用的空间比int更小。
为了确保在不同平台上的数据范围一致性,可以使用stdint头文件定义的类型,如int32_t,确保固定字节长度。
C语言的整型类型及其使用方法,是深入理解C语言编程的关键部分,通过实际操作和实践,你将更好地掌握它们。想要了解更多关于C语言的课程内容,可以查看相关链接。
㈡ C语言中整型常量有几种表示方法
在C语言中,整型常量有三种书写形式:
(1) 十进制整数。十进制整数就是通常整数的写法。例如:11、15、21等。
(2) 八进制整数。八进制整数的书写形式是在通常八进制整数的前面加一个数字0。例如:00、0111、015、021等,它们分别表示十进制整数:0、73、13、17
(3) 十六进制整数。十六进制整数的书写形式是在通常十六进制整数的前面加0x。例如:0x0、0x111、0x15、0x21等,它们分别表示十进制整数0、273、21、33。
注意,整型常量前面没有+或者-,-10其实是一元-运算符和操作数10,同样整型常量的十进制表示并没有0,单独写一个0其实是一个八进制常量。
(2)c语言中的整型扩展阅读
转换为整型
要明示地将一个值转换为 integer,用 (int) 或 (integer)强制转换。不过大多数情况下都不需要强制转换,因为当运算符,函数或流程控制需要一个 integer 参数时,值会自动转换。您还可以通过函数 intval() 来将一个值转换成整型。
1、从布尔值转换
FALSE 将产生出0(零),TRUE 将产生出1(壹)。
2、从浮点数转换
当从浮点数转换成整数时,数字将被取整(丢弃小数位)。
注意:如果浮点数超出了整数范围(通常为 +/- 2.15e+9 = 2^31),则结果不确定,因为没有足够的精度使浮点数给出一个确切的整数结果。在此情况下没有警告,甚至没有任何通知!
注:在 Linux 下返回结果是最小负数(-214748),而在 Windows 下返回结果是零(0)。
【以下以C/C++语言为例,陈述一下整型的知识】:
a、C/C++对整型长度的规定是为了执行效率,将int定义为机器字长可以取得最大的执行速度;
b、C/C++中整型包括:int,char和enum,C++中还包含bool类型,C99中bool是一个宏,实际为_Bool;
c、C和C++对enum的规定有所不同,这里不描述;
d、修饰整型正负的有signed和unsigned,对于int默认为signed;
e、修饰 int 大小的有short和long,部分编译器还扩展了一些更长的整型,比如long long和__int64, C99中增加了long long和unsigned long long;
f、int 的长度与机器字长相同,16位的编译器上int长16位,32位的编译器上int长32位;
g、short int的长度小于等于int 的长度,注意它们可能长度相等,这取决于编译器;
h、long int 的长度大于等于int 的长度,注意它们可能长度相等,这取决于编译器;
i、char 的长度应当可以包容得下一个字符,大部分系统中就是一个字节,而有的系统中可能是4个字节,因为这些系统中一个字符需要四个字节来描述;
j、char 的正负取决于编译器,而编译器的决定取决于操作系统,在不同的编译器中char可能等同于signed char,也可能等同于unsigned char。
参考资料来源:网络-整型
参考资料来源:网络-整型常量