zoukankan      html  css  js  c++  java
  • C语言printf()函数:格式化输出函数

    C语言printf()函数:格式化输出函数

    头文件:#include <stdio.h>

    printf()函数是最常用的格式化输出函数,其原型为:
        int printf( char * format, ... );

    printf()会根据参数 format 字符串来转换并格式化数据,然后将结果输出到标准输出设备(显示器),直到出现字符串结束('')为止。

    参数 format 字符串可包含下列三种字符类型:
    • 一般文本,将会直接输出
    • ASCII 控制字符,如 、 等有特定含义
    • 格式转换字符

    格式转换为一个百分比符号(%)及其后的格式字符所组成。一般而言,每个%符号在其后都必需有一个参数与之相呼应(只有当%%转换字符出现时会直接输出%字符),而欲输出的数据类型必须与其相对应的转换字符类型相同。

    printf()格式转换的一般形式如下:
        %(flags)(width)(. prec)type
    以括号括起来的参数为选择性参数,而%与type 则是必要的,下面介绍 type 的几种形式。

    1) 整数
    • %d  整数的参数会被转成有符号的十进制数字
    • %u  整数的参数会被转成无符号的十进制数字
    • %o  整数的参数会被转成无符号的八进制数字
    • %x  整数的参数会被转成无符号的十六进制数字,并以小写abcdef 表示
    • %X  整数的参数会被转成无符号的十六进制数字,并以大写ABCDEF 表示浮点型数
    • %f double  型的参数会被转成十进制数字,并取到小数点以下六位,四舍五入
    • %e double  型的参数以指数形式打印,有一个数字会在小数点前,六位数字在小数点后,而在指数部分会以小写的e 来表示
    • %E 与%e 作用相同,唯一区别是指数部分将以大写的E 来表示
    • %g double  型的参数会自动选择以%f 或%e 的格式来打印,其标准是根据打印的数值及所设置的有效位数来决定。
    • %G 与%g 作用相同,唯一区别在以指数形态打印时会选择%E 格式。

    2) 字符及字符串
    • %c 整型数的参数会被转成unsigned char 型打印出
    • %s 指向字符串的参数会被逐字输出,直到出现NULL 字符为止
    • %p 如果是参数是"void *"型指针则使用十六进制格式显示

    prec 有几种情况:
    • 正整数的最小位数
    • 在浮点型数中代表小数位数
    • 格式代表有效位数的最大值
    • 在%s 格式代表字符串的最大长度
    • 若为×符号则代表下个参数值为最大长度

    width 为参数的最小长度,若此栏并非数值,而是*符号,则表示以下一个参数当做参数长度。

    flags 有下列几种情况
    • +  一般在打印负数时,printf ()会加印一个负号,整数则不加任何负号,此旗标会使得在打印正数前多一个正号 (+)。
    • #  此旗标会根据其后转换字符的不同而有不同含义。当在类型为o 之前 (如%#o),则会在打印八进制数值前多印一个o。而在类型为x 之前 (%#x)则会在打印十六进制数前多印'0x',在型态为e、E、f、g 或G 之前则会强迫数值打印小数点。在类型为g 或G 之前时则同时保留小数点及小数位数末尾的零。
    • 0  当有指定参数时,无数字的参数将补上0。默认是关闭此旗标,所以一般会打印出空白字符。

    【返回值】成功则返回写入的字符数目。

    如果发生写入错误,将会设置文件错误标志(可通过 ferror() 检测),并返回一个负数。

    如果在写入宽字符时一个多字节的字符发生编码错误,那么 errno 将被设置为 EILSEQ,并返回一个负数。

    printf( format, ... ) 等价于 fprintf(stdout, format, ...),更多信息请参考 fprintf() 函数。

    【实例】分别输出整数、浮点数和字符串。
    1. #include<stdio.h>
    2. int main(void)
    3. {
    4. int a=1;
    5. float b=5.0;
    6. char str[100]= "";
    7. scanf("%c %c %c",&a,&b,str);
    8. /*分别演示 整数*/
    9. printf("int is:%d ",a);
    10. /*分别演示 浮点数*/
    11. printf("float is:%f ",b);
    12. /*分别演示 字符串*/
    13. printf("char is:%s ",str);
    14. return 0;
    15. }
    输出结果:
    【运行结果】
    1 4.4 fs
    int is:1
    float is:4.400000
    char is:fs

    例子首先是等待用户输入整数浮点数和一个字符串,然后调用函数printf()按照对应的格式输出。

    又如,输出更多格式的数据。
    1. #include <stdio.h>
    2. int main()
    3. {
    4. printf ("Characters: %c %c ", 'a', 65);
    5. printf ("Decimals: %d %ld ", 1977, 650000L);
    6. printf ("Preceding with blanks: %10d ", 1977);
    7. printf ("Preceding with zeros: %010d ", 1977);
    8. printf ("Some different radices: %d %x %o %#x %#o ", 100, 100, 100, 100, 100);
    9. printf ("floats: %4.2f %+.0e %E ", 3.1416, 3.1416, 3.1416);
    10. printf ("Width trick: %*d ", 5, 10);
    11. printf ("%s ", "A string");
    12. return 0;
    13. }
    输出结果:
    Characters: a A
    Decimals: 1977 650000
    Preceding with blanks:       1977
    Preceding with zeros: 0000001977
    Some different radices: 100 64 144 0x64 0144
    floats: 3.14 +3e+000 3.141600E+000
    Width trick:    10
    A string
  • 相关阅读:
    TVM量化代码解析
    如何在 GPU 上优化卷积
    全文翻译(全文合集):TVM: An Automated End-to-End Optimizing Compiler for Deep Learning
    全文翻译(四) TVM An Automated End-to-End Optimizing Compiler
    全文翻译(三) TVM An Automated End-to-End Optimizing Compiler
    全文翻译(二): TVM: An Automated End-to-End Optimizing Compiler for Deep Learning
    全文翻译(一):TVM: An Automated End-to-End Optimizing Compiler for Deep Learning
    pytorch使用gpu加速的方法
    springboot的实践1
    带你玩转stackOverflow-3
  • 原文地址:https://www.cnblogs.com/sddai/p/5399469.html
Copyright © 2011-2022 走看看