C语言中整型常量有几种形式,它们是如何表示的?

2021-11-03 科技 399阅读

在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。

参考资料来源:百度百科-整型

参考资料来源:百度百科-整型常量

声明:你问我答网所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流。若您的权利被侵害,请联系fangmu6661024@163.com