1.基本数据类型
C语言允许使用的数据类型有三类。
(1) 基本类型。不可再分的最基本的数据类型,包括整型、浮点(单精度)型、双精度型、字符型、无值类型、逻辑型及复数型。基本类型通常代表单个数据。
(2) 构造类型。由已知的基本类型通过一定的构造方法构造出来的类型,包括数组、结构体、联合体、枚举类型等。构造类型通常代表一批数据。
(3) 指针类型。指针可以指向内存地址,访问效率高,用于构造各种形态的动态或递归数据结构,如链表、树等。
1.1 基本数据类型
1.基本数据类型及其关键字
C99标准提供的7种基本数据类型及其对应的关键字如表所示。
数据类型 关键字
字符型 char
整型 int
浮点(单精度)型 float
双精度型 double
无值类型 void
逻辑型 _bool
复数型 _complex_imaginary
字符型:描述单个字符;
整型:描述整数,整数在计算机上是准确表示的;
浮点型、双精度型:描述实数,实数在计算机上一般是近似表示的,浮点型的近似程度比较低,而双精度型的近似程度比较高。
无值类型:没有具体的值,通常用来描述无形式参数或无返回值的C函数,以及无定向指针。
逻辑型:描述逻辑真(其值为1)与逻辑假(其值为0)。
复数型:描述复数(_complex)和纯虚数(_imaginary)。
使用逻辑型时必须包含头文件stdbool.h,使用复数型时必须包含头文件complex.h。
2.基本数据类型的存储方式和取值范围、基本数据类型的扩展
类型 长度字节 取值范围 存储方式
char 1 -128~127 有符号二进制补码形式
[signed]char 1 -128~127
unsigned char 1 0~255
short [int] 2 -32768~32767
unsigned short [int] 2 0~65535
int 4 -2147483648~2147483647 定点有符号二进制补码形式
[signed] int 4 -2147483648~2147483647
unsigned [int] 4 0~4294967295
long [int] 4 -2147483648~2147483647
[signed] long [int] 4 -2147483648~2147483647
unsigned long [int] 4 0~4294967295
float 4 -3.4*10^38~3.4*10^38 浮点形式存储
double 8 -1.798*10^308~1.798*10^308 浮点形式存储
long double 8 -1.798*10^308~1.798*10^308
ps:signed为有符号(可以正数也可复数) unsigned 为无符号 (只有正数)
2.占位符
%@ 对象
%d, %i 整数
%li 长整型
%u 无符号整形
%f 浮点/双字
%x, %X 十六进制整数
%o 八进制整数
%zu size_t
%p 指针
%e 浮点/ 双字 (科学计算) (double)
%g 浮点/ 双字 (double)
%s C字符串
%.*s Pascal字符串
%c 字符
%C unichar
%lld 64位长整数(longlong)
%llu 无符号64位长整数
%Lf64位双数
%% %转义
%@: Objective-C对象,印有字符串返回descriptionWithLocale:如果于的话,或描述相反.CFTypeRef工作对象,返回的结果的CFCopyDescription功能.(这个翻译有问题建议按照自己的理解方式理解)。
%%: 为'%'字符;
%d,%D,%i: 为32位整型数(int);
%u,%U: 为32位无符号整型数(unsignedint);
%hi: 为有符号的16位整型数(short);
%hu: 为无符号的16位整型数(unsignedshord);
%qi: 为有符号的64位整型数(longlong);
%qu: 为无符号的64位整型数(unsignedlonglong);
%x: 为32位的无符号整型数(unsignedint),打印使用数字0-9的十六进制,小写a-f;
%X: 为32位的无符号整型数(unsignedint),打印使用数字0-9的十六进制,大写A-F;
%qx: 为无符号64位整数(unsignedlonglong),打印使用数字0-9的十六进制,小写a-f;
%qX: 为无符号64位整数(unsignedlonglong),打印使用数字0-9的十六进制,大写A-F;
%o,%O: 为32位的无符号整数(unsignedint),打印八进制数;
%f: 为64位的浮点数(double);
%e: 为64位的浮点数(double),打印使用小写字母e,科学计数法介绍了指数的增大而减小;
%E: 为64位的浮点数(double),打印科学符号使用一个大写E介绍指数的增大而减小;
%g: 为64位的浮点数(double),用%e的方式打印指数,如果指数小于4或者大于等于精度,那么%f的风格就会有不同体现;
%G: 为64位的浮点数(double),用%E的方式打印指数,如果指数小于4或者大于等于精度,那么%f的风格就会有不同体现;
%c: 为8位的无符号字符%c(unsignedchar),通过打印NSLog()将其作为一个ASCII字符,或者,不是一个ASCII字符,八进制格式\ddd或统一标准的字符编码的十六进制格式\udddd,在这里d是一个数字;
%C: 为16位Unicode字符%C(unichar),通过打印NSLog()将其作为一个ASCII字符,或者,不是一个ASCII字符,八进制格式\ddd或统一标准的字符编码的十六进制格式\\udddd,在这里d是一个数字;
%s: 对于无符号字符数组空终止,%s系统中解释其输入编码,而不是别的,如utf-8;
%S: 空终止一系列的16位Unicode字符; %p: 空指针(无效*),打印十六进制的数字0-9和小写a-f,前缀为0x;
%L: 在明确规定的长度下,进行修正,下面的一批数据a,A,e,E,f,F,g,G应用于双精度长整型的参数;
%a: 为64位的浮点数(double),按照科学计数法打印采用0x和一个十六进制数字前使用小写小数点p来介绍指数的增大而减小;
%A: 为64位的浮点数(double),按照科学计数法打印采用0X和一个十六进制数字前使用大写字母小数点P界扫指数的增大而减小;
%F: 为64位的浮点数(double),按照十进制表示法进行打印;
%z: 修改说明在%z长度以下d,i,o,u,x,X适用于某一指定类型的转换或者适用于一定尺寸的整数类型的参数;
%t: 修改说明在%t长度以下d,i,o,u,x,X适用于某一指定类型或一定尺寸的整数类型的转换的参数;
%j: 修改说明在%j长度以下d,i,o,u,x,X适用于某一指定类型或一定尺寸的整数类型的转换的参数
例:
int i = 100;
double d = 200;
float f = 200;
long l = 100;
short s = 100;
char c = 'D';
// 字符串 char*
// 输出打印 ,要用占位符
printf("i的值是:%d\n",i);
printf("d的值是:%lf\n", d);
printf("f的值是:%f\n", f);
printf("l的值是:%ld\n", l);
printf("s的值是:%d\n", s);
printf("c的值是:%c", c);
7. 枚举的定义和使用 枚举有点类似于 int
enum CommentType
{
TEXT = 10,TEXT_IMAGE,IMAGE
};
void main(){
CommentType commentType = TEXT;
CommentType commentType1 = TEXT_IMAGE;
CommentType commentType2 = IMAGE;
printf("%d,%d,%d", commentType, commentType1, commentType2);
getchar();
}