数据类型关键字
文章目录
一、最初K&R给出的关键字
1.int
有符号整型数据,可以是正整数、负整数或零。
#include "stdio.h"
int main()
{
int x = 10; //创造内存空间并赋初值10
printf("%d\n", x); //显示十进制--10
printf("%o\n", x); //显示八进制--12
printf("%#o\n", x); //显示带前缀的八进制--012
printf("%x\n", x); //显示十六进制--a
printf("%#x\n", x); //显示带前缀的十六进制--0xa
return 0;
}
2.long
long int 或者 long 占用的存储空间比 int 多,适用于较大数值的场合,为有符号类型;
long long int 或者 long long 占用的存储空间可能比 long 多,适用于更大的数值的场合,至少占64位,为有符号的类型。
printf 函数输出格式 %ld或**%lld**。
3.short
short int类型(short)占用的存储空间可能比 int 少,应用于较小的数值场合以节省空间,为有符号类型。
printf 函数输出格式 %hd、%ho。
4.unsigned
unsigned int 或者 unsigned 只用于非负值场合,可以表示更大的数;
C90标准添加了 unsigned long int 或 unsigned long 和 unsigned int 或 unsigned short 类型;
C99标准添加了 unsigend long long int 或者 unsigned long long。
printf 函数输出格式 %u如:%llu
5.整型数据类型的选择
首先,考虑unsigned类型。这种类型的数常用于计数,因为计数不用负数。而且,unsigned类型可以表示更大的正数。
如果一个数超出了int类型的取值范围,且在long类型的取值范围内时,使用long类型。然而,对于那些long占用的空间比int大的系统,使用long类型会减慢运算速度。因此,如非必要,请不要使用long类型。
另外要注意一点:如果在long类型和int类型占用空间相同的机器上编写代码,当确实需要32位的整数时,应使用long类型而不是int类型,以便把程序移植到16位机后仍然可以正常工作。类似地,如果确实需要64位的整数,应使用long long类型。
如果在int设置为32位的系统中要使用16位的值,应使用short类型以节省存储空间。通常,只有当程序使用相对于系统可用内存较大的整型数组时,才需要重点考虑节省空间的问题。使用short类型的另一个原因是,计算机中某些组件使用的硬件寄存器是16位。
6.char
char类型用于储存字符(如,字母或标点符号),但是从技术层面看,
char是整数类型。因为char类型实际上储存的是整数而不是字符。
/* charcode.c-显示字符的代码编号 */
#include <stdio.h>
int main(void)
{
char ch;
printf("Please enter a character.\n");
scanf("%c", &ch); /* 用户输入字符 */
printf("The code for %c is %d.\n", ch, ch);
return 0;
}
运行该程序后,输出示例如下:
Please enter a character.
138
C
The code for C is 67.
7.float
浮点类型能表示包括小数在内更大范围的数。浮点数的表示类似于科学记数法(即用小数乘以10的幂来表示数字)。
float类型必须至少能表示6位有效数字,且取值范围至少是10-37~10+37。
8.double
double类型和float类型的最小取值范围相同,但至少必须能表示10位有效数字。一般情况下,double占用64位而不是32位。
9.long double
C语言的第3种浮点类型是long double,以满足比double类型更高的精度
要求。不过,C只保证long double类型至少与double类型的精度相同。
二、C90标准添加的关键字
1.signed
在任何有符号的类型前面添加关键字signed,可强调使用有符号类型的意图。
2.void
二、C11标准添加的关键字
1._Bool
C99标准添加了_Bool类型,用于表示布尔值,即逻辑值true和false。因
为C语言用值1表示true,值0表示false,所以_Bool类型实际上也是一种整数
类型。但原则上它仅占用1位存储空间
2._Complex
C语言有3种复数类型:float_Complex、double_Complex和long double _Complex。例如,float _Complex类型的变量应包含两个float类型的值,分别表示复数的实部和虚部。
3._Imaginry
类似地, C语言的3种虚数类型是float_Imaginary、double _Imaginary和long double _Imaginary。