1.类型安全:
支持强类型的观点认为明确的类型有助于尽早发现程序中的简单错误。
反对强类型的观点认为过于强调类型迫使程序员面对底层、实现而非事务逻辑。
总体来说,早期语言、面向底层的语言强调类型。
C语言需要类型,但是对类型的安全检查并不足够。
2.C语言的类型
整数:char、short、int、long、long long
浮点数:float、double、long double
逻辑:bool
指针
自定义类型
long long和long double和bool都是C99的类型。
3.类型有何不同
类型名称:int、long、double
输入输出时的格式化:%d、%ld、%lf
所表达的数的范围:char<short<int<float<double
内存中所占据的大小:1个字节到16个字节
内存中的表达形式:二进制数(补码)、编码
(整型数是自然二进制码或者二进制的补码,而浮点数是一种编码形式,不是二进制数)
4.sizeof
是一个运算符,给出某个类型或变量在内存中所占据的字节数。
sizeof(int);
sizeof(i);
sizeof是静态运算符,它的结果在编译时刻就决定了。
不要在sizeof的括号里做运算,这些运算是不会做的。见下例:
#include <stdio.h>
int main()
{
int a;
a=6;
printf("sizeof(int)=%ld\n",sizeof(int));
printf("sizeof(a++)=%ld\n",sizeof(a++));
printf("a=%d\n",a);
printf("sizeof(a+1.0)=%ld\n",sizeof(a+1.0));
printf("a=%d\n",a);
return 0;
}
输出结果为:
即sizeof在编译时就通过判断括号内的表达式的结果应该是什么类型,根据这个类型就决定了sizeof以及括号内的内容整体会被替换成什么样的数字。如例子中当a++在sizeof中已经在编译时被定下来了,这个a++并没有产生实际要执行的代码,所以a的值不变。
而下面a+1.0得到的结果会默认转换为double类型,所以sizeof输出结果为8,但a的值仍然未变。
4.整数
类型 | 字节数 |
---|---|
char | 1 |
short | 2 |
int | 取决于编译器(CPU),通常的意义是“1个字” |
long | 取决于编译器(CPU),通常的意义是“1个字” |
long long | 8 |
所以32位机器和64位机器的整数类型字节数有可能不同,亦或编译器版本不同,在同一机器上字节数也不同。