美文网首页
C&C++常用方法笔记 - 基本数据类型&占位符

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

作者: 月影路西法 | 来源:发表于2019-05-05 10:18 被阅读0次

    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++常用方法笔记 - 基本数据类型&占位符

          本文链接:https://www.haomeiwen.com/subject/uefcoqtx.html