printf()的转换说明的修饰符中的标记、数字、和.数字
先记下代码和运行结果
再解释
#include <stdio.h>
#include <stdlib.h>
#include <limits.h> #define PAGES 959
int main(int argc,char* argv)
{
printf("*%d*\n",PAGES);
printf("*%+2d*\n",PAGES);
printf("*%10d*\n",PAGES);
printf("*%-10d*\n",PAGES);
printf("*%010d*\n",PAGES);
printf("*%-010d*\n",PAGES);
printf("*%-010.2d*\n",PAGES);
printf("*%-010.5d*\n",PAGES);
printf("*%010.5d*\n",PAGES); const double RENT = 3852.99;
printf("----------------------------------\n");
printf("*%f*\n",RENT);
printf("*%e*\n",RENT);
printf("*%4.2f*\n",RENT);
printf("*%3.1f*\n",RENT);
printf("*%10.3f*\n",RENT);
printf("*%10.3E*\n",RENT);
printf("*%+4.2f*\n",RENT);
printf("*%010.2f*\n",RENT);
printf("*%-10.2f*\n"); return ;
}
结果为:
*959*
*+959*
* 959*
*959 *
*0000000959*
*959 *
*959 *
*00959 *
* 00959*
----------------------------------
*3852.990000*
*3.852990e+03*
*3852.99*
*3853.0*
* 3852.990*
* 3.853E+03*
*+3852.99*
*0003852.99*
*3852.99 *
说明:
首先这三种修饰符,即标记、数字和.数字,他们必须按照这个顺序书写,不能变换顺序。
标记包括5种:+-空格#0
+:表示显示符号位
-:待打印项左对齐,即待打印的项位于整个字段的最左边。这里解释一下,这里所说的字段是指整个转换说明,比如"%-10d",这个字段不仅包括%d表示的数字还包含一些空格位,因为整个字段的长度为10个字符位,如果数字不够则需要用空格填充,默认情况是空格填充在左侧,但是使用了-符号后,数字要左对齐,就是数字出现在最左侧,然后才是补充的空格。
空格:还没明白,明白了再添加
#:用于显示八进制和十六进制的前导符。
0:以0填充。前面说到不足的字符位默认是空格填充,如果使用0标记,则用0填充,当然,0填充只能是在数的前面(左侧)填充,要不然数的大小就变啦!所以当使用-标记表示左对齐的时候0表示是没有作用的。
数字修饰符:用于表示这个字段(前面已经解释了字段的含义)所占的字符位的个数。例如%10d表示这个字段占10位,如果数字本身不足10位则默认情况用空格填充(填充在左侧),如果数字本身已经超过10位,数字标记就不起作用了
.数字修饰符:对于整数,表示整数的最小位数,如%.5d ,如果数字本身的位数小于5位,则会填充0以达到五位数(填充位置自然是数的左侧),如果数本身就大于5位,那么可以认为这个标记不起作用。
对于浮点数,表示的是小数点右边的数字的位数,默认情况下浮点数好像会显示小数点右边的六位。
这三种修饰符通常情况下会一起使用,分析的时候一定要注意这三个修饰符出现的顺序一定是先标记再数字最后是点数字(当然其中一项或多项没有可以不使用)。牢记这一点然后再分析就容易了。
11月26日添加:
对于标记空格的理解:
先给出代码:
#include <stdio.h>
#include <stdlib.h>
int main(int argc,char* argv)
{ printf("%d\t%d\t%d\t%d\t%d\t%d\n",,,,-,);
printf("%d\t%d\t%d\t%d\t%d\t%d\n",-,,-,,,);
printf("----------------------------------------------------------------------------------------------------------------------\n\n\n"); // 添加数字标记使每个字段占用的字符位数相同
printf("%9d\t%9d\t%9d\t%9d\t%9d\t%9d\n",,,,-,);
printf("%9d\t%9d\t%9d\t%9d\t%9d\t%9d\n",-,,-,,,);
printf("----------------------------------------------------------------------------------------------------------------------\n\n\n"); //添加-标记,使数字作对其
printf("%-9d\t%-9d\t%-9d\t%-9d\t%-9d\t%-9d\n",,,,-,);
printf("%-9d\t%-9d\t%-9d\t%-9d\t%-9d\t%-9d\n",-,,-,,,);
printf("----------------------------------------------------------------------------------------------------------------------\n\n\n"); //添加空格标记,使正数前面生成前导空格
printf("% -9d\t% -9d\t% -9d\t% -9d\t% -9d\t% -9d\n",,,,-,);
printf("% -9d\t% -9d\t% -9d\t% -9d\t% -9d\t% -9d\n",-,,-,,,);
printf("----------------------------------------------------------------------------------------------------------------------\n\n\n"); //多个空格呢,会当成一个空格来处理
printf("% -9d\t% -9d\t% -9d\t% -9d\t% -9d\t% -9d\n",,,,-,);
printf("% -9d\t% -9d\t% -9d\t% -9d\t% -9d\t% -9d\n",-,,-,,,);
printf("----------------------------------------------------------------------------------------------------------------------\n\n\n"); //空格标记和-标记的顺序调换一下
printf("%- 9d\t%- 9d\t%- 9d\t%- 9d\t%- 9d\t%- 9d\n",,,,-,);
printf("%- 9d\t%- 9d\t%- 9d\t%- 9d\t%- 9d\t%- 9d\n",-,,-,,,);
printf("----------------------------------------------------------------------------------------------------------------------\n\n\n"); return ;
}
运行结果:
说明: 在转换说明中使用空格标记的作用是:在输出的正值前面生成前导空格,负值前面不产生前导空格,这样输出的结果比较美观。
打印多行数据的时候,我们经常使用\t 来控制输出,使输出更加美观。但是当数字的位数大于8的时候,用\t也不能完全解决(第一种代码)。这时我们可以在转换说明中加入数字修饰(第二种代码),来控制每个字段所占字符的位数,我们发现,这种情况比上一种情况美观了很多。但是有时候我们希望数据左对齐而不是右对齐,这时我们就可以在转换说明中使用-标记(第三种代码),采用的第三种代码后,我们发现,输出更加美观了,但是仍然存在一个小的瑕疵,就是正数和负数不能对其,这个时候我们可以在转换说明中再加入空格标记(第四种代码),使得输出更加美观。最后我们测试了一下使用多个空格作为标记,发现效果和使用一个空格是一样的(第五种代码),也就是说转换说明中使用空格标记,多个空格都被视为一个空格。最后我们还将空格标记和-标记的位置进行了调换(第六种代码),发现和第五种情况一样。说明,在转换说明中使用标记时,对五种标记的顺序没有要求,但是切记,正如前面一再强调的那样,标记修饰一定要在数字修饰的前面,数字修饰一定要在.数字修饰的前面。
补充:
对于整型变量来说,当0标记和.数字修饰同时使用时,零标记将失去作用。
printf()的转换说明的修饰符中的标记、数字、和.数字的更多相关文章
- Java中volatile修饰符,不稳定标记的用法笔记
今天学java特性时,发现了volatile修饰符,这个修饰符修饰的变量告诉java编译器忽略优化机制,这样的优势是: java优化后,寄存器会缓存内存里的变量,另一个线程修改这个变量的内存时,不会同 ...
- php中的修饰符
上面使用了一个修饰符U,详见关于修饰符的介绍. PHP正则表达式修饰符的理解: 在PHP正则表达式里面的修饰符可以改变正则的很多特性,使得正则表达式更加适合你的需要(注意:修饰符对于大小写是敏感的,这 ...
- as3 中 final 修饰符
现在,在ActionScript 3.0的修饰符中,只有final修饰符没有介绍.之所有放在这里介绍,是因为final修饰符只与继承有关,指定一个方法不能被重写或一个类不能被继承. 一般来说,当用fi ...
- @property的4类修饰符
一.读写性修饰符:readwrite | readonly readwrite:表明这个属性是可读可写的,系统为我们创建这个属性的setter和getter方法. readonly:表明这个属性只能读 ...
- PHP 正则表达式 修饰符
下面列出了当前可用的 PCRE 修饰符.括号中提到的名字是 PCRE 内部这些修饰符的名称. 模式修饰符中的空格,换行符会被忽略,其他字符会导致错误. i (PCRE_CASELESS) 如果设置了这 ...
- PHP正则表达式模式修饰符详解
PHP模式修饰符又叫模式修正符,是在正则表达式的定界符之外使用.主要用来调整正则表达式的解释,提扩展了正则表达式在匹配.替换等操作的某些功能,增强了正则的能力.但是有很多地方的解释都是错误的,也容易误 ...
- PHP正则表达式模式修饰符 /i, /is, /s, /isU等
模式修饰符 下面列出了当前可用的 PCRE 修饰符.括号中提到的名字是 PCRE 内部这些修饰符的名称. 模式修饰符中的空格,换行符会被忽略,其他字符会导致错误. i (PCRE_CASELESS) ...
- C# JAVA成员访问修饰符比较
在面向对象的访问修饰符中常用的有public ,private ,protected C# 访问修饰符: private < protected internal < internal/p ...
- 从零开始学 Web 之 Vue.js(二)过滤器,按键修饰符,自定义指令
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
随机推荐
- 【转】【译】在 Windows 10 应用程序中注册任意依赖属性的改变
原文地址:http://visuallylocated.com/post/2015/04/01/Registering-to-any-DependencyProperty-changing-in-Wi ...
- Toad 实现 SQL 优化
It is very easy for us to implement sql tuning by toad. We need to do is just give complex sql stat ...
- 一起学习MVC(2)Global.asax的学习
在Global.asax.cs文件中 protected void Application_BeginRequest(Object sender, EventArgs e) { ...
- [翻译]NUnit---SetUp and SetUpFixture and Suite Attributes(十九)
SetUpAttribute (NUnit 2.0 / 2.5) 本特性用于TestFixture提供一个公共的功能集合,在呼叫每个测试方法之前执行.同时也用在SetUpFixture中,SetUpF ...
- 设计模式之状态模式(State Pattern)
一.什么是状态模式? 把所有动作都封装在状态对象中,状态持有者将行为委托给当前状态对象 也就是说,状态持有者(比如汽车,电视,ATM机都有多个状态)并不知道动作细节,状态持有者只关心自己当前所处的状态 ...
- MySQL远程连接失败,MySQL远程连接出现Using password:YES错误的解决办法
相信很多实用MYSQL的朋友都遇到过这种问题,就是MySQL使用localhost能够连接成功,但是使用IP连接却出现Using password:YES或者其它的连接错误.今天就把解决方法给大家说一 ...
- vs 2015 结合新配置的IIS 发布网站过程中遇到的问题及解决办法?
1.由于扩展配置问题而无法提供您请求的页面.如果该页面是脚本,请添加处理程序 错误: HTTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面.如果该页面是脚本,请添 ...
- Ocelot中文文档入门
入门 Ocelot仅适用于.NET Core,目前是根据netstandard2.0构建的,如果Ocelot适合您,这个文档可能会有用. .NET Core 2.1 安装NuGet包 使用nuget安 ...
- Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'img' at row 1故障
Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'img' at ro ...
- PHP7 - 如何禁用Xdebug
操作系统:Cent OS 7 什么是Xdebug?看它的官方网站介绍: https://xdebug.org/index.php 为什么要禁用呢?这是因为Composer,这两种工具有冲突,在使用Co ...