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个字节,范围为:
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--)