7.C语言--数据类型

C语言是一种有类型的语言。C语言需要类型,但它不是一种强类型的语言。

C语言的类型:

整数:char、short、int、long、long long

浮点数:float、double、long double

逻辑:bool

指针

自定义类型

类型的不同:

类型的名字不同:int、long、double

输入输出时的格式化:%d、%ld、%lf

所表达的数的范围:char<short<int<float<double

内存中所占据的大小:1个字节到16个字节

内存中的表达形式:整形的变量是二进制数或者补码形式,浮点数是一种编码形式,不能直接做运算。

sizeof()函数

sizeof(变量);可以得到变量占的字节数

sizeof();是一个静态运算符。

int main()

{

int a = 6;

print("sizeof(a++)=%d\n",sizeof(a++));

printf("a = %d\n",a);

return 0;

}

输出结果为:

sizeof(a++)=4

a =6

编译器在编译的时候,碰到sizeof()的时候,它里面的类型为整形,就用4去替换它,并没有计算a++,因为事先用4替换了它。


int 通常是4字节

long 也通常是4字节

整数二进制存储:

18->00010010

0->00000000

-18-> ?

负数怎么表达呢?



负数的补码是去掉负号的整数部分。正整数的源码,反码,补码都是自己本身。


int main()

{

    char c = 255;

    int i = 255;

    printf("c = %d,i =  %d\n",c,i);

    return 0;

}

输出为:c = -1,i = 255

C程序默认类型都是有符号的;

char类型只有8位,

255->11111111  -> -1

int类型为4个字节,范围为:

-x^{32-1}到x^{32-1}-1

unsigned 关键字 表示无符号类型

整数的输入输出:







%e是输入输出科学计数法。

n是整数

%.nf 表示输出到小数点后n位。

列:%.3f 表示输出到小数点后三位。

12.0/0.0 = inf (inf表示正无穷大)

-12.0/0.0 = -inf

0.0/0.0 = nan (nan表示不存在)

浮点运算的精度:

#include<stdio.h>

int main()

{

float a,b,c;

a  = 1.345f;

b = 1.123f;

c = a+b;

if (c == 2.468)

printf("相等\n");

else

printf ("不行等 ! c = %.10f,或%f\n",c,c);

return 0;

}

运行结果 :不相等 !c = 2.4679999352,或2.468000

带小数点的字面量是double而非float。float需要f或F表明身份。

浮点数是不精确的,不能用浮点数算银行的钱,因为随着计算的次数增加,误差会累加。要想算精确的小数运算,把钱用分做单位,并用整数存储,运算。输出的时候在换算成元。


最高位表示正负。处理器里有专门的硬件计算浮点数。








编译器自己内部机制类型转换




逻辑运算符:bool

想要使用布尔类型需要包含一个头文件

#include<stdbool.h>

就可以使用bool、true、false

逻辑运算符:

! ->逻辑非 ;&&  -> 逻辑与; ||  ->逻辑或

想要表达数学中的区间,如 4< x<6。程序中的 4< x<6 ,会先做 4 <x ,结果是一个逻辑值 0 或1,然后再和 6比较。无论下是什么值 最后都输出逻辑1 。在程序中正确的表达方式为:4< x && x <6


单目运算符的优先级比多目优先级要高。




条件运算符:

count = (count>20)?count - 10 :count+10;

上面的代码可相当于下面代码:

if (count > 20 )

    count = count -10;

else

    count  = count +10;

条件运算符的优先级高于赋值运算符,但是低于其他运算符。

条件运算符是自右向左结合的。一般不提倡用嵌套条件运算符。

试试读下下面代码:

count = (count > 20)?(count <50)? count - 10:count - 5:(count <10)?count + 10:count +5;

逗号运算符,用来连接两个表达式,并以右边的表达式的值作为它的结果。它的优先级低于所有的运算符,组合关系自左向右,左边的表达式会先计算,右边的表达式的值就会留下来作为逗号运算符的结果。下面举例:

i= 3+4,5+6;

i = 7,赋值优先级大于逗号,所以先把4+3的值赋给了i,5+6的值没有赋值给i。

i= (3+4,5+6);

i = 11,

逗号运算符主要在for循环中使用。

for (i = 0,j = 10; i<j; i++,j--)

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容