printf的格式控制的完整格式



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运行了,可是[这行]处有错误,不知道为什么,怎么办呢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1 目标检测的定义 目标检测(Object Detection)的任务是找出图像中所有感兴趣的目标(物体),确定它们的类别和位置,是计算机视觉领域的核心问题之一。由于各类物体有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具有挑战性的问题。 目标检测任务可分为两个关键的子任务,目标定位和目标分类。首先检测图像中目标的位置(目标定位),然后给出每个目标的具体类别(目标分类)。输出结果是一个边界框(称为Bounding-box,一般形式为(x1,y1,x2,y2),表示框的左上角坐标和右下角坐标),一个置信度分数(Confidence Score),表示边界框中是否包含检测对象的概率和各个类别的概率(首先得到类别概率,经过Softmax可得到类别标签)。 1.1 Two stage方法 目前主流的基于深度学习的目标检测算法主要分为两类:Two stage和One stage。Two stage方法将目标检测过程分为两个阶段。第一个阶段是 Region Proposal 生成阶段,主要用于生成潜在的目标候选框(Bounding-box proposals)。这个阶段通常使用卷积神经网络(CNN)从输入图像中提取特征,然后通过一些技巧(如选择性搜索)来生成候选框。第二个阶段是分类和位置精修阶段,将第一个阶段生成的候选框输入到另一个 CNN 中进行分类,并根据分类结果对候选框的位置进行微调。Two stage 方法的优点是准确度较高,缺点是速度相对较慢。 常见Tow stage目标检测算法有:R-CNN系列、SPPNet等。 1.2 One stage方法 One stage方法直接利用模型提取特征值,并利用这些特征值进行目标的分类和定位,不需要生成Region Proposal。这种方法的优点是速度快,因为省略了Region Proposal生成的过程。One stage方法的缺点是准确度相对较低,因为它没有对潜在的目标进行预先筛选。 常见的One stage目标检测算法有:YOLO系列、SSD系列和RetinaNet等。 2 常见名词解释 2.1 NMS(Non-Maximum Suppression) 目标检测模型一般会给出目标的多个预测边界框,对成百上千的预测边界框都进行调整肯定是不可行的,需要对这些结果先进行一个大体的挑选。NMS称为非极大值抑制,作用是从众多预测边界框中挑选出最具代表性的结果,这样可以加快算法效率,其主要流程如下: 设定一个置信度分数阈值,将置信度分数小于阈值的直接过滤掉 将剩下框的置信度分数从大到小排序,选中值最大的框 遍历其余的框,如果和当前框的重叠面积(IOU)大于设定的阈值(一般为0.7),就将框删除(超过设定阈值,认为两个框的里面的物体属于同一个类别) 从未处理的框中继续选一个置信度分数最大的,重复上述过程,直至所有框处理完毕 2.2 IoU(Intersection over Union) 定义了两个边界框的重叠度,当预测边界框和真实边界框差异很小时,或重叠度很大时,表示模型产生的预测边界框很准确。边界框A、B的IOU计算公式为: 2.3 mAP(mean Average Precision) mAP即均值平均精度,是评估目标检测模型效果的最重要指标,这个值介于0到1之间,且越大越好。mAP是AP(Average Precision)的平均值,那么首先需要了解AP的概念。想要了解AP的概念,还要首先了解目标检测中Precision和Recall的概念。 首先我们设置置信度阈值(Confidence Threshold)和IoU阈值(一般设置为0.5,也会衡量0.75以及0.9的mAP值): 当一个预测边界框被认为是True Positive(TP)时,需要同时满足下面三个条件: Confidence Score > Confidence Threshold 预测类别匹配真实值(Ground truth)的类别 预测边界框的IoU大于设定的IoU阈值 不满足条件2或条件3,则认为是False Positive(FP)。当对应同一个真值有多个预测结果时,只有最高置信度分数的预测结果被认为是True Positive,其余被认为是False Positive。 Precision和Recall的概念如下图所示: Precision表示TP与预测边界框数量的比值 Recall表示TP与真实边界框数量的比值 改变不同的置信度阈值,可以获得多组Precision和Recall,Recall放X轴,Precision放Y轴,可以画出一个Precision-Recall曲线,简称P-R
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值