zoukankan      html  css  js  c++  java
  • printf函数详细讲解

    (1)简介

    printf函数是c语言当中非常重要的格式化输出函

    其函数原型为:int printf(const char *format, ...);

    其函数返回值:打印出的字符格式

    其调用格式为:printf("<格式化字符串>", <参量表>);

    (2)转换说明:

    转换格式为:%[标志][宽度][.精度][类型长度]类型

    除了最后的类型之外都是可选的字段

    标志
    标志  意义
    -

    项目是左对齐的;也就是说,会把项目打印在字段的左侧开始处。示例:"%-20s"

    +

    有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:"%+6.2f"

    (空格)

    带符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志;示例:"% 6.2f"

    #

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

    0

    对于所有的数字格式,用前导0而不是用空格填充字段。如果出现-标志或者指定了精度(对于整数)则忽略该标志;示例:"%010d"

    宽度,精度
    修饰符 意义
    digit(s) 字段宽度的最小。如果该字段不能容纳要打印的数或者字符串,系统就会使用更宽的字段。示例:"%4d"
    .digit(s) 精度,对于%e,%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导0来达到这个位数。只使用"."表示其后跟随一个零,所以%.f和%.0f相同;示例:"%5.2f"打印一个浮点数,他的字段宽度为5个字符,小数点后面有两位数字
    类型长度
    修饰符 意义
    h 和整数转换说明符一起使用,表示一个short int或unsigned short int类型数值;示例:"%hu" "%hd" "%hx"
    hh 和整数转换说明符一起使用,表示一个signed char或unsigned char类型数值;示例:"%hhu" "%hhd" "%hhx"
    j 和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值;示例:"%jd" "%jX"
    l 和整数转换说明符一起使用,表示一个long int或unsigned long int类型数值;示例:"%lu" "%ld"
    ll 和整数转换说明符一起使用,表示一个long long int或unsigned long long int类型数值(c99);示例:"%llu" "%lld"
    L 和浮点转换说明符一起使用,表示一个long double值;示例:"%Lf" "%Le"
    t 和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差对应的类型)(c99);示例:"%td"
    z 和整数转换说明符一起使用,表示一个size_t值(sizeof返回类型)(c99);示例:"%zd"
    I64 和整数转换说明符一起使用,表示一个_int64值
    转换说明符
    转换说明 输出
    %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 使用十六进制数0x的无符号十六进制整数
    %X 使用十六进制数字0X的无符号十六进制证书
    %% 打印一个百分号

    (3)示例:

     1 #include <stdio.h>
     2 
     3 int main() {
     4     const char * pString = "Hello World";
     5     const int    nNumber = 1024;
     6     const double dNumber = 3.141593;
     7     //  %d  示例
     8     printf("*%d*
    ", nNumber);          //输出:*1024*
     9     printf("*%6d*
    ", nNumber);         //输出:*  1024*
    10     printf("*%6.5d*
    ", nNumber);       //输出:* 01024*
    11     printf("*%-6.5d*
    ", nNumber);      //输出:*01024 *
    12     printf("*%06d*
    ", nNumber);        //输出:*001024*
    13     printf("*%+6d*
    ", nNumber);        //输出:* +1024*
    14 
    15     //  %f  示例
    16     printf("*%f*
    ", dNumber);          //输出:*3.141593*
    17     printf("*%10f*
    ", dNumber);        //输出:*  3.141593*
    18     printf("*%10.2f*
    ", dNumber);      //输出:*      3.14*
    19     printf("*%-10.2f*
    ", dNumber);     //输出:*3.14      *
    20     printf("*%+10.2f*
    ", dNumber);     //输出:*     +3.14*
    21     printf("*%010.2f*
    ", dNumber);     //输出:*0000003.14*
    22 
    23     //  %s  示例
    24     printf("*%s*
    ", pString);          //输出:*Hello World*
    25     printf("*%20s*
    ", pString);        //输出:*         Hello World*
    26     printf("*%-20s*
    ", pString);       //输出:*Hello World         *
    27     printf("*%.10s*
    ", pString);       //输出:*Hello Worl*
    28     return 0;
    29 }

    (4)浮点参数的转换:

    有用于打印浮点类型double和long double的转换说明符,但没有用于float的说明符。原因是在K&R C中float值在被用于表达式中或者被用作参数之前,会被自动转换成double类型。一般情况下,ANSI C不会自动把float转换成double。不过,为了保护大量现有的假设float参数仍会自动被转换成double。因此,不过是K&R C还是ANSI C,都无需专门的转换说明符来显示float。

  • 相关阅读:
    java中文件的读取和写入
    ==与equal在java中应用的感悟
    Gson心得小笔记
    几种排序的算法
    HttpClient的使用方法
    StringBuffer
    laravel5.5容器
    常用会话管理方式
    css一些事儿
    关于时间的梳理
  • 原文地址:https://www.cnblogs.com/windpiaoxue/p/9183506.html
Copyright © 2011-2022 走看看