Linux C语言开发-D4数据类型

数据类型分类

Linux C语言开发-D4数据类型_第1张图片

bool类型:非零为真(true),零为假(false),其在头文件中

255=2的8次方-1

127=2的7次方-1

-128的补码是:10000000

一定要注意长度和范围,防止内存越界

类型名称 字节(32) 值域
char 1 -128~127或0~255
signd char 1 -128~127
unsignd char 1 0~255
short(signed short) 2 -32768~32767
unsignd short 2 0~65535
float 4
double 8

%f是float,%lf是double,%d是整形十进制,%x是整形十六进制,%o是整形八进制,%c是char

头文件中包含可查看具体的每一种数据类型的范围

vi /usr/include/limits.h可查看此头文件

Linux C语言开发-D4数据类型_第2张图片

强制类型转换

是指采用某种方式将某种数据类型强制转换成指定的数据类型。包括显式的数据类型转换和隐式的数据类型转换

显式类型转换:不安全,将一个高精度类型赋给一个低精度类型,将一个大的数据类型赋给一个小的数据类型

隐式自动类型转换遵循以下规则:

若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
a、若两种类型的字节数不同,转换成字节数高的类型
b、若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型
所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
char型和short型参与运算时,必须先转换成int型。
在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。

你可能感兴趣的:(Linux,c语言,c语言,linux,1024程序员节)