printf的格式控制的完整格式

本文详细介绍了C语言中printf函数的格式控制方法,包括各种格式字符的使用方式及其参数的意义,如左对齐输出、指定空位填充等。此外还探讨了一些高级用法,如通过*m.ns格式控制字符串输出的具体细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



printf的格式控制的完整格式


%  -  0  m.n  l
格式字符
下面对组成格式说明的各项加以说明:
%:表示格式说明的起始符号,不可缺少。
-:有-表示左对齐输出,如省略表示右对齐输出。
0:有0表示指定空位填0,如省略表示指定空位不填。
m.nm指域宽,即对应的输出项在输出设备上所占的字符数。N指精度。用于说明输出的实型数的小数位数。为指定n时,隐含的精度为n=6位。
lh:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。

---------------------------------------
格式字符
格式字符用以指定输出项的数据类型和输出格式。
 
d格式:用来输出十进制整数。有以下几种用法:
%d
:按整型数据的实际长度输出。
%md
m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
%ld
:输出长整型数据。
o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。
例:
   main()
   { int a = -1;
     printf("%d, %o", a, a);
   }
 
运行结果:-1,177777
 
程序解析:-1在内存单元中(以补码形式存放)为(1111111111111111)2,转换为八进制数为(177777)8
x格式:以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。
u格式:以无符号十进制形式输出整数。对长整型可以用"%lu"格式输出。同样也可以指定字段宽度用“%mu”格式输出。
c格式:输出一个字符。
s格式:用来输出一个串。有几中用法
%s
:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)。
%ms
:输出的字符串占m列,如字符串本身长度大于m,则突破获m的限制,将字符串全部输出。若串长小于m,则左补空格。
%-ms
:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。
%m.ns
:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
%-m.ns
:其中mn含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。
f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:
%f
:不指定宽度,整数部分全部输出并输出6位小数。
%m.nf
:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。 
%-m.nf
:输出共占n列,其中有n位小数,如数值宽度小于m右端补空格。
e格式:以指数形式输出实数。可用以下形式:
%e
:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。
%m.ne
%-m.nemn”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。
g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。

---------------------------------------
关于printf函数的进一步说明:
如果想输出字符"%",则应该在格式控制字符串中用连续两个%表示,如:
printf("%f%%", 1.0/3);
输出0.333333%

---------------------------------------
对于单精度数,使用%f格式符输出时,仅前7位是有效数字,小数6位.
对于双精度数,使用%lf格式符输出时,前16位是有效数字,小数6位.

######################################拾遗########################################
由高手指点
对于m.n的格式还可以用如下方法表示(例)
char ch[20];
printf("%*.*s\n",m,n,ch);
前边的*定义的是总的宽度,后边的定义的是输出的个数。分别对应外面的参数mn 。我想这种方法的好处是可以在语句之外对参数mn赋值,从而控制输出格式。


今天(06.6.9)又看到一种输出格式 %n 可以将所输出字符串的长度值赋绐一个变量, 见下例:

int slen;

printf("hello world%n", &slen);

执行后变量被赋值为11


又查了一下, 看到一篇文章(查看)说这种格式输出已经确认为一个安全隐患,并且已禁用。再搜搜果然这种用法都被用来搞什么溢出、漏洞之类的,随便找了一个:格式化字符串攻击笔记

 

 


版权声明:编程爱好者网站为此博客服务提供商,如本文牵涉到版权问题,编程爱好者网站不承担相关责任,如有版权问题请直接与本文作者联系解决。谢谢!

评论

评论人: 匿名 发布时间: 2009-9-22 16:01:00

main 函数后的括号要是在英文状态下输入的

评论人: wentao 发布时间: 2006-2-17 23:40:00

[]你说的是不是TCOptions的那个Directories的设置?好像要设置成完整的路径名,我的TCD,我这样设置的:
Include directories: D:\TURBOC\INCLUDE
Library directories: D:\TURBOC\LIB
Output directory:    D:\TURBOC\WORK(
这个自己设
)
Turbo C directory:   D:\TURBOC
如果你有谭浩强的《C程序设计题解与上机指导(第二版)》在第186页有"确立TC工作环境"的介绍。我也不太清楚,你再看看吧。

评论人: 飘枫倾月 发布时间: 2006-2-17 20:53:00

请教:怎么在director中设置编译和链接的路径

评论人: 飘枫倾月 发布时间: 2006-2-17 19:48:00

make是在compile菜单里的,可一次完成编译和连接,你可以试一下,我也是初学,多多交流阿

评论人: wentao 发布时间: 2006-2-17 13:39:00

[:周星星]关于TCVC
我还是不太明白,按您的说法,我们平时写的
void main()
这种写法是错误的吗那又是不是应该写成
int main()
然后再在main里面最后加一个return我们这些初学只能用TC,VC这些"民用级产品",对其他编译器不了解,想必您这样的高手说他烂一定是有根据的,那推荐一个好点的编译器吧.期待中
……
多谢多谢!

评论人: 周星星 发布时间: 2006-2-17 13:28:00

[:wentao]
:)是啊,星号表示由参数获得宽度。

评论人: 周星星 发布时间: 2006-2-17 13:26:00

 wentao 说:
你认为VC下的结果有什么问题?TC16位的C编译器,因此int也是16位;而VC32位的C编译器,因此int也是32位;

唯一的错误在于main函数的返回值,无论是C还是C++都规定main函数的返回值只能是int。当然像TCVC这种烂编译器对标准的支持是很差的。

评论人: wentao 发布时间: 2006-2-17 13:20:00

[:周星星]
研究并运行了一下你说的printf( "%0*d", 10, 4 );感觉那个*应该是控制位宽的,其值由外面的参数(这里是10)决定,又查了查资料,有这么个说法
:
char ch[20];
printf("%*.*s\n",m,n,ch);
前边的*定义的是总的宽度,后边的定义的是输出的个数。这和我原文中所说的m.n应该是一个功能吧,只是这里的mn在引号外说明而已,不知是不是这样,请指教!

多谢多谢!

评论人: wentao 发布时间: 2006-2-17 13:02:00

[:飘枫倾月]
你说的是不是语法错误?那个main后面的()你绐写打成中文的了,改成英文的就行了啊.我在VC6.0Turbo C下都试了,能运行,没啥错误啊.只是VC下的结果有点问题,我也不太明白,还需高手指点.你说的make是不是Turbo C下的那个,我没用过,也不知它是干啥的,说来听听
?
Turbo C
下结果
:
a=-1,177777,ffff,65535
b=-2,177776,fffe,65534
VC
下结果
:
a=65535,177777,ffff,65535
b=-2,37777777776,fffffffe,4294967294
出自:谭老的《C程序设计(第二版)》 74页例4.3

评论人: 周星星 发布时间: 2006-2-17 11:10:00

^_^ "完整格式"有一点点夸张:
printf( "%0*d", 10, 4 ); 
中星号的用法就没有提到。

评论人: 飘枫倾月 发布时间: 2006-2-17 7:18:00

我用printf时,为什么说有错误呢,请看一下
#include<stdio.h>     [
这行]
void main
()

{
unsigned int a =65535;
int b=-2;
printf("a=%d,%o,%x,%u\n",a,a,a,a);     [
这行]
printf("b=%d,%o,%x,%u\n",b,b,b,b);
}
我用make运行了,可是[这行]处有错误,不知道为什么,怎么办呢

内容概要:本文档详细介绍了一个基于MATLAB实现的跨尺度注意力机制(CSA)结合Transformer编码器的多变量时间序列预测项目。项目旨在精准捕捉多尺度时间序列特征,提升多变量时间序列的预测性能,降低模型计算复杂度与训练时间,增强模型的解释性和可视化能力。通过跨尺度注意力机制,模型可以同时捕获局部细节和全局趋势,显著提升预测精度和泛化能力。文档还探讨了项目面临的挑战,如多尺度特征融合、多变量复杂依赖关系、计算资源瓶颈等问题,并提出了相应的解决方案。此外,项目模型架构包括跨尺度注意力机制模块、Transformer编码器层和输出预测层,文档最后提供了部分MATLAB代码示例。 适合人群:具备一定编程基础,尤其是熟悉MATLAB和深度学习的科研人员、工程师和研究生。 使用场景及目标:①需要处理多变量、多尺度时间序列数据的研究和应用场景,如金融市场分析、气象预测、工业设备监控、交通流量预测等;②希望深入了解跨尺度注意力机制和Transformer编码器在时间序列预测中的应用;③希望通过MATLAB实现高效的多变量时间序列预测模型,提升预测精度和模型解释性。 其他说明:此项目不仅提供了一种新的技术路径来处理复杂的时间序列数据,还推动了多领域多变量时间序列应用的创新。文档中的代码示例和详细的模型描述有助于读者快速理解和复现该项目,促进学术和技术交流。建议读者在实践中结合自己的数据集进行调试和优化,以达到最佳的预测效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值