`
msn877763580
  • 浏览: 83778 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

[转]C语言printf

 
阅读更多

From:http://www.cnblogs.com/shiney/archive/2011/08/19/2145921.html

1.调用格式为  printf("<格式化字符串>", <参量表>);
  其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式化规定字符, "%"开始, 后跟一个或几个规定字符用来确定输出内容格式。参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。

2.格式化字符

%d 十进制有符号整数
%u
十进制无符号整数
%f
浮点数
%s
字符串
%c
单个字符
%p
指针的值
%e
指数形式的浮点数
%x, %X
无符号以十六进制表示的整数
%0
无符号以八进制表示的整数
%g
自动选择合适的表示法
说明:
(1).
可以在"%"和字母之间插进数字表示最大场宽。 例如: %3d 表示输出3位整型数, 不够3位右对齐。 %9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6, 小数点占一位, 不够9位右对齐。%8s 表示输出8个字符的字符串, 不够8个字符右对齐。 如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。 但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出; 若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。另, 若想在输出值前加一些0, 就应在场宽项前加个0 例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度4位。如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度, 小数点前的数字代表最小宽度。 例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 9个字符以后的内容将被删除。
(2).
可以在"%"和字母之间加小写字母l, 表示输出的是长型数。例如: %ld 表示输出long整数, %lf 表示输出double浮点数。
(3).
可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可说明输出为左对齐, 否则为右对齐。例如: %-7d 表示输出7位整数左对齐,%-10s 表示输出10个字符左对齐。

 


3. 一些特殊规定字符
\n换行
\f
清屏并换页
\r
回车
\t Tab

\xhh
表示一个ASCII码用16进表示,
其中hh1216进制数

int a=1234;
    printf("a=%d\n",a);    //a=1234
    printf("a=%2d\n",a);   //a=1234    超过2位,按实际输出
   printf("a=%6d\n",a);   //a=  1234  不足6位,右对齐
   printf("a=%06d\n",a);  //a=001234  不足6位,前面补0
    printf("a=%-6d\n",a);  //a=1234    '-'左对齐
    

   int* i=&a;
    printf("i=%p\n",i);    //i=0012FF44  输出指针的值,即地址

   float m=8888.8888;   //float 单精度型浮点数 有效位数是6位或7位,根据不同的浮点数会有不同
   float m1=8888.8888f;    //在后面加上f或F,编译警告:truncation from'const double'to 'float'
                  //编译器默认浮点数为double
    float m2=8888.888f;  
    double n=8888.8888;
    double n1=8888888888.88888888;  //double 双精度型浮点数 有效位数是15位
    printf("m=%f\n m1=%f\n m2=%f\n n=%lf\n n1=%f\n",m,m1,m2,n,n1); // m=8888.888672
                                                                //  m1=8888.888672     
                                                                //  m2=8888.887695
                                                               // n=8888.888800
                                                               // n1=8888888888.888889
                                                               //%f的默认输出小数位数就是6位不管有没有l
    /*printf的%f说明符的确既可以输出float型又可以输出 double型。 根据"默认参数提升"规则(在printf这样的函数的
    可变参数列表中 ,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到
    双精度数。严格地讲,%lf在printf下是未定义的,但是很多系统可能会接受它。要确保可移植性,就要坚持使用%f。*/

    printf("m4=%4.2f\n",m);   //宽度总共4位,小数两位,小数点一位,整数一位,这里整数超过宽度规定,按实际整数位输出
    printf("m5=%9.6f\n",m);   //浮点数小数部分不足6位,右对齐
    printf("m6=%9.2f\n",m);   //整数部分不足6位,右对齐;小数部分超过2位,四舍五入

    char c[20]="Hello,world!";
    printf("c=%s\n",c);    
    printf("c=%6.9s\n",c);  //c=Hello,wor  6.9s表示输出一个长度长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。

 

 

分享到:
评论

相关推荐

    printf用法大全,C语言printf格式控制符一览表.docx

    ### C语言printf函数详解 #### 一、printf函数概述 `printf`函数是C语言中最常用的输出函数之一,用于向标准输出设备(通常是屏幕)输出指定格式的数据。它定义在`stdio.h`头文件中,因此在使用时需要包含此头文件...

    C语言里printf函数完整用法

    C语言里printf函数格式控制符的完整格式 printf的格式控制的完整格式: % - 0 m.n l或h 格式字符

    C语言printf与scanf讲解.pdf

    C语言printf与scanf讲解.pdf

    C语言Printf详解[归纳].pdf

    C语言Printf详解[归纳].pdf

    printf_c.tar_C语言printf_

    简述C语言如何编写源文件,linux编译生成可运行文件,简简单单的printf语句

    C语言 printf 打印格式大全

    包含了所有printf输出格式,如有缺失,忘诸君不吝赐教,适合所有使用C语言的学者查阅,善用printf调试大法的学者必备的调试参考资料

    (55条消息) c语言打印格式大全,C语言printf()输出格式大全_武耀峰的博客-CSDN博客.mhtml

    (55条消息) c语言打印格式大全,C语言printf()输出格式大全_武耀峰的博客-CSDN博客.mhtml

    C语言精彩教案-最新版

    - 调试技巧:使用printf()进行调试输出,了解gdb等调试工具的使用。 这份【C语言精彩教案-最新版】将通过丰富的示例代码、练习题和解析,帮助你熟练掌握C语言的各个方面。无论是准备面试、项目开发还是自学提升,...

    printf函数的原型和重定义

    printf 函数的原型和重定义 printf 函数是 C 语言中一个常用的输出函数,它可以将格式化的字符串输出到标准输出设备上。在嵌入式开发领域中,printf 函数经常被重定义以满足特定的需求。本文将详细介绍 printf ...

    C语言中printf的使用.zip_C语言_printf函数

    printf()函数是式样化输出函数, 一般用于向准则输出设备按规定式样输出消息。正在编写步骤时经常会用到此函数。printf()函数的挪用式样为: printf(&quot;&lt;式样化字符串&gt;&quot;,&lt;参量表&gt;);

    自己写的printf,但是不能输出float型的数据

    在C语言中,`printf`函数的灵活性来自于其格式化字符串,其中`%f`是用来指定输出浮点数的。要自己实现`printf`功能并处理浮点数,我们需要理解以下几点: 1. **格式化字符串解析**:首先,你需要解析输入的格式化...

    各种进制间转换——c语言

    在计算机科学中,进制转换是一项基础且至关重要的技能,特别是在C语言编程中。C语言是一种底层编程语言,它允许程序员直接处理二进制、八进制、十进制和十六进制等不同进制的数值。这篇文档“各种进制转换_c语言.doc...

    c语言printf实现同一位置打印输出的实例

    C语言printf实现同一位置打印输出的实例 C语言printf实现同一位置打印输出的实例是指使用C语言的printf函数在控制台上实现同一个位置打印输出,例如进度1%-&gt;100%在同一位置显示。这种技术可以广泛应用于命令行界面...

    详解C语言中printf输出的相关函数

    C语言printf()函数:格式化输出函数 printf()函数是最常用的格式化输出函数,其原型为: int printf( char * format, ... ); printf()会根据参数 format 字符串来转换并格式化数据,然后将结果输出到标准输出...

    C语言实现Printf函数完整工程文件

    在C语言中,`printf`函数是用于格式化输出数据的标准库函数,它在`stdio.h`头文件中被定义。这个"C语言实现Printf函数完整工程文件"提供了一个自定义实现`printf`功能的机会,这有助于理解其内部工作原理,并可以...

    C语言IO--printf右对齐补零

    C语言IO--printf右对齐补零 C语言IO中,printf函数是格式化输出函数,用于向标准输出设备按规定格式输出信息。printf函数的调用格式为:printf("&lt;格式化字符串&gt;", &lt;参量表&gt;); 其中,格式化字符串包括两部分内容:...

    C语言中printf函数的功能注解

    ### C语言中printf函数的功能注解 #### 一、引言 在C语言编程中,基本的输入输出功能主要是通过调用标准库函数实现的。其中,`printf`函数是功能强大且常用的输出函数之一。本文将详细介绍`printf`函数的功能,并...

    C语言中printf函数的功能注解.pdf

    《C语言中printf函数的功能注解》 C语言是一门基础且强大的编程语言,其中的printf函数是进行输出操作的核心工具。本文详细阐述了printf函数的功能,并提供了在使用过程中应注意的事项,旨在帮助读者更准确、高效地...

Global site tag (gtag.js) - Google Analytics