C&C++常用方法笔记 - 基本数据类型&占位符

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();

}

你可能感兴趣的:(C&C++常用方法笔记 - 基本数据类型&占位符)