10. 基本数据类型:整型(上)
1. 整型 int C 语言提供了很多整数类型(整型),这些整型的区别在于它们的取值范围的大小,以及是否可以为负。int 是整型之一,一般被称为整型。
正如我们在以前的教程里看到的那样,int 用于声明整型变量:以 int 打头,后面跟着变量的名字,最后以分号(;)结束。例如: int erns; /* 声明一个变量 */ 以上声明创建了变量,但是没有给它们提供“值(value)”。在前面的教程中,我们已经用了两种方法使变量获得“值”。一种是赋值:cows = 500; 。另一种是使用 scanf 函数:scanf( "%d", &goats ); 。下面我们来学习第三种方法。
初始化变量是指给变量赋初值:声明变量的时候,在变量名的后面写上等号(=),然后写下你希望赋予变量的“值”。例如: int hogs = 21; 以上声明创建了变量,并且为这些变量分配了空间,同时也赋了初值。注意,第三行中只有 cats 被初始化为 94,而 dogs 没有被初始化!如下图:
上面的例子中,21、32、14,以及 94 都是整数常量。C 语言中,整数常量的默认类型是 int ,也就是说,整数常量占用内存空间的大小一般等于 int 类型的变量占用空间的大小。如果整数常量的大小超过了 int 的取值范围,那么编译器将会把这个整数常量当作 long int 类型来处理,这个我们后面还会讲到。
int year = 2005; /* year 是 int 型变量 */ 保证格式限定符的数目和参数数目一致是我们的责任,编译器不负责捕捉这种错误!例如: #include <stdio.h> int main(void) printf("%d minus %d is %d\n", ten ); /* 少写了两个参数 */ getchar(); /* 等待用户按回车 */ 这个程序可以通过编译,但是运行结果将会出乎意料,因为我们少写了两个参数。第一个 %d 被参数 ten 的值代替,而另外两个 %d 将被内存中本来储存着的值代替。因为内存中本来储存着的值是不确定的,所以输出结果是不确定的。
C 语言中,整数常量默认是十进制(decimal)整数。通过在整数常量前面加上特定的前缀,可以把它设定为八进制或者十六进制整数。前缀 0x 或者 0X 把整数常量设定为十六进制整数。注意,是数字 0 ,而不是字母 O ,别搞错了哦!例如:十进制的 16 用十六进制来表示是 0x10 或者 0X10 。在整数常量前面加上前缀 0 ,表示它是八进制整数。注意,是数字 0 ,而不是字母 O 。例如:十进制的 16 表示为八进制就是 020 。
使用格式限定符 %o 可以以八进制的形式输出整数。注意,是小写字母 o ,不是数字 0 。使用 %x 或者 %X 可以以十六进制的形式输出整数。小写 x 表示输出使用小写字母,大写 X 表示输出使用大写字母。使用 %#o,%#x 或者 %#X,得到的输出将包括前缀 0,0x 或者 0X。例如: #include <stdio.h> int main(void) printf("dec = %d; octal = %o; hex = %x; HEX = %X\n", x, x, x, x); getchar(); 这个程序的输出是: dec = 200; octal = 310; hex = c8; HEX = C8 |
11. 基本数据类型:整型(中) |
1. 其它整数类型 int 是 C 语言的基本整数类型,可以满足我们处理一般数据的需求。C 语言还提供了四个可以修饰int的关键字:short、long、signed,以及unsigned。利用这四个关键字,C 语言标准定义了以下整数类型: 1) short int(可简写为 short),和 int 一样,也是有符号整数 一般我们把 short 称为短整型,把 long 称为长整型,把 long long 称为超长整型,把 int 称为整型。unsigned 打头的那些整数类型统称为无符号整型。例如:我们称 unsigned short 为无符号短整型。以此类推。
这些整数类型的声明方式与 int 类型的声明方式一样。例如: long int estine; 如果您的编译器不支持C99标准,那就不能使用long long和unsigned long long。
标准也规定了这些整数类型的最小取值范围。short 的最小表示范围和 int 一样,都是 -32767 到 32767 。也就是 -(2^15 - 1)到(2^15 - 1)。其中,2^15表示 2 的 15 次方。类似地,2 的 20 次方记作 2^20 ,以此类推。注意:C 语言中 2^15 并不表示 2 的 15 次方,为了书写方便,我们姑且这么表示。long 的最小取值范围是 -2147483647 到 2147483647 。也就是 -(2^31 - 1) 到 printf( "%lu\n", (unsigned long)sizeof(int) * 8 ); /* 输出 int 的位数 */ sizeof 的用法我们以后会讲到,现在只要有个印象就好了。第二句中的 %zu 是 C99 特有的,如果您的编译器不支持 C99(准确地说,应该是如果您的编译器使用的库函数不支持 C99),运行结果将会出错。
如果您要处理的只是正整数,那么应该优先使用 unsigned 打头的那些整数类型。如果您要处理的整数超出了int所能表示的范围,并且您的编译器中,long的表示范围比 int 大,那就使用 long 。不过,若非必要,尽量不要用 long ,因为它可能会降低程序运行效率。有一点要注意:如果您的编译器中,long和int都是32位的,并且您需要使用32位整数,那么应该用long,而不要用int。只有这样,我们的程序才可以安全地移植到16位的计算机,因为 16位的计算机中,int 一般也是16位的。类似地,如果您需要使用64位整数,那就用 long long。如果 int 是 32 位的话,那么使用 short 可以节省空间,不过您得确保您要处理的整数不会超出 short 的表示范围。这种“节省”对内存大的计算机来说,是没什么意义的。 5. long 型常量和 long long 型常量 一般来说,整数常量是被当作 int 类型来存储的。如果我们使用的整数常量超出了 int 的表示范围,C 语言规定编译器自动使用 unsigned int 来处理这个常量。如果 unsigned也不足以表示这个常量的话,编译器就会用long 。如果还表示不了的话,那就依次用unsigned long,long long,unsigned long long。如果unsigned long long也表示不了,那么编译器就没辙了。注意:long long 和unsigned long long 是 C99 特有的。例如:如果 int 是 16 位的话,它就表示不了常量 1000000。编译器会使用 long 来处理这个常量,因为 unsigned int 也表示不了 1000000 。 |