在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其实是一个八进制常量。
扩展资料
转换为整型
要明示地将一个值转换为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,部分编译器还扩展了一些更长的整型,比如longlong和__int64,C99中增加了longlong和unsignedlonglong;
f、int的长度与机器字长相同,16位的编译器上int长16位,32位的编译器上int长32位;
g、shortint的长度小于等于int的长度,注意它们可能长度相等,这取决于编译器;
h、longint的长度大于等于int的长度,注意它们可能长度相等,这取决于编译器;
i、char的长度应当可以包容得下一个字符,大部分系统中就是一个字节,而有的系统中可能是4个字节,因为这些系统中一个字符需要四个字节来描述;
j、char的正负取决于编译器,而编译器的决定取决于操作系统,在不同的编译器中char可能等同于signedchar,也可能等同于unsignedchar。
参考资料来源:
参考资料来源: