zoukankan      html  css  js  c++  java
  • 【C语言】printf函数详解

    C语言printf函数详解

     一、相关基础知识                                                 

    请求printf()打印变量的指令取决于变量的类型,例如打印整数用%d符号,打印字符用%c符号,这些符号称为转换说明(conversion specification),因为它们指定了如何把数据转换成可显示的形式

     二、具体内容                                                     

    printf的使用格式:

    printfControl-stringitem1item2,。。。);

    控制字符串(control-string):是一个描述项目如何打印的字符串,所以需要使用双引号“”,以及应该为每个要打印的项目包含一个转换说明符,且必须一一对应,不可多一少一,就算在最好情况下也只能得到无意义的值!

    项目:item1item2等等都是要打印的项目,可以是变量、常量,甚至可以是需要计算的表达式

    下列列出的是ANSI C标准printf()提供的各种转换说明

    转换说明

    输出

    %a

    浮点数、十六进制数字和p-记数法(C99)

    %A

    浮点数、十六进制数字和P-记法(C99)

    %c

    一个字符

    %d

    有符号十进制整数

    %e

    浮点数、e-记数法

    %E

    浮点数、E-记数法

    %f

    浮点数、十进制记数法

    %g

    根据数值不同自动选择%f或%e%e格式在指数小于-4或者大于等于精度时使用

    %G

    根据数值不同自动选择%f或%E%E格式在指数小于-4或者大于等于精度时使用

    %i

    有符号十进制数(与%d相同)

    %o

    无符号八进制整数

    %p

    指针

    %s

    字符串

    %u

    无符号十进制整数

    %x

    使用十六进制数字0f的无符号十六进制整数0f中是数字0,而不是字母o

    %X

    使用十六进制数字0F的无符号十六进制整数

    %%

    打印一个百分号

    可以在%和定义转换字符之间通过插入修饰符对基本的转换说明加以修改,如果使用了一个以上的修饰符,那么它们应该与上表中出现的顺序相同,也并不是所有的组合都是可能的

    下列列出的是printf()修饰符

    修饰符

    意义

    标志

    五种标志 (-、+、空格、0) 都将在后表中描述,可以使用零个或多个标志

    例如:”%-10d”

    digit(s)

    字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统会使用更宽的字段。示例:“%4d”,字段宽度包括符号,即12.235位!

    即A.B形式中的A,下面的精度为A.B形式中的B当位数不足会在前面自动补空格,超过正常显示

    .digit(s)

    精度。对于%e%E%f转换,是将要在小数点的右边打印的数字的位数。对于%g%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导零来达到这个位数。只使用“.”表示其后跟随一个零,所以%.f%.0f相同。示例:“%5.2f”打印一个浮点数,他的字段宽度为5个字符,小数点后有两个数字。

    h

    和整数转换说明符一起使用,表示一个short int 或者 unsigned short int 类型数值。

    示例:“%hu”“%hx”“%6.4hd”

    hh

    和整数转换说明符一起使用,表示一个signed char 或者unsigned char类型数值。

    示例:“%hhu”“%hhx”“%6.4hhd”

    j

    和整数转换说明符一起使用,表示一个intmax_tuintmax_t值。

    示例:“%jd”“%8jX”

    l(字母)

    和整数说明符一起使用,表示一个long int 或者unsigned long int 类型值。

    示例:“%ld”“%8lu”

    ll(字母)

    和整数说明符一起使用,表示一个long long int unsigned long long int 类型值 (C99)。

    示例:“%lld”“%8llu”

    L

    和浮点转换说明符一起使用,表示一个long double值。

    示例:“%Lf”“%10.4Le”

    t

    和整数转换说明符一起使用,表示一个ptrdiff_t(与两个指针之间的差相对应的类型) (C99)

    示例:“%td”“%12ti”

    z

    和整数转换说明符一起使用,表示一个size_t(sizeof返回的类型(C99)。

    示例:“%zd”“%12zx”

    下列列出的是printf()的标志

    标志

    意义

    -

    项目是左对齐的:也就是说,会把项目打印在字段的左侧开始处

    例如:”%-20s”

    +

    有符号的值若为正,则显示带加号的符号:若为负,则带减号的符号

    例如:”%+6.2f”

    (空格)

    有符号的值若为正,则显示带前导空格(但是不显示符号):若为负,则带减号符号。+标示会覆盖空格标志

    例如:”% 6.2f”

    #

    使用转换说明的可选形式。若为%o格式,则以0开始;若为%x%X格式,则以0x0X开始,对于所有的浮点形式,#保证了即使不限任何数字,也打印一个小数点字符。对于%g%G格式,它防止尾随零被删除。

    例如:“%#o”、“%#8.0f”和“%+#10.3E

    0

    对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志。

    例如:“%010d”和“%08.3f

    printf函数也有一个返回值,它返回所打印的字符的数目,如果输出错误,那么printf()会返回一个负数,使用返回值得一个可能原因是要检查输出错误,比如在读入文件输出的时候进行判断

     三、分析总结                                                     

    当打印较多内容时可以采用下列两种方法:

    一、使用反斜杠符号   ,在上一行的末尾加上,下一行即可继续,注意下一行必须删除前面的空格,否则也会输出前面的空格

    例如:

        printf("asdasdad

    sadasdadad ");          //输出连续的字符串

        

        printf("asdasdad

    sadasdadad ");     //输出带空格的字符串,asdasda      adadasdas

    二、可直接使用多个双引号拼接,可不用删除前面的空格,建议使用

    例如:

        printf("sadasda"

    "dasdada"

             "dasdada"

    "dasdada");            //输出连续的asdadadadasdadadasdadadada

        

     四、实例测试                                                     

  • 相关阅读:
    跳板机操作
    常用进制之间的转换
    vim加脚本注释和文本加密
    LAMP框架
    wiki团队协作软件Confluence
    NFS网络文件系统
    ORACLE-12C-RAC INSTALL
    通过DB_LINK按照分区表抽取数据
    Oracle Rac crs无法启动
    删除undotbs后,数据库无法启动
  • 原文地址:https://www.cnblogs.com/Ahair/p/5017050.html
Copyright © 2011-2022 走看看