printf("%*s\n", 1, ""); 使用"printf();" 的格式化输出动态制定等宽度输出。
#include <stdio.h>
#include <string.h> int main()
{
const char the_text[] = "this is test text!"; // 在C 语言中输出等宽度的显示我们一般采用的是在前面加数字的方法,
printf("%30s\n", the_text); // 右对齐输出,结果:" this is test text!"
printf("%-30s\n", the_text); // 左对齐输出,结果:"this is test text! " // 其实C 语言还对printf() 提供了一种动态添加的方法,也就是可以使用变量的方法来
// 设置该宽度,这样就大大提高了等宽度输出的灵活性。 const char text_char[] = "char";
const char text_char_var[] = "m_ch_var";
const char text_char_ptr[] = "m_ch_ptr";
const char text_int32[] = "int32_t";
const char text_int32_var[] = "m_nvar";
const char text_int32_ptr[] = "m_pvar"; printf("%s %*s%s;\n", text_char, - strlen(text_char), "", text_char_var);
printf("%s*%*s%s;\n", text_char, - strlen(text_char), "", text_char_ptr);
printf("%s %*s%s;\n", text_int32, - strlen(text_int32), "", text_int32_var);
printf("%s*%*s%s;\n", text_int32, - strlen(text_int32), "", text_int32_ptr);
// (13 + ...) 的结果是"std::vector<%s>" 的总字节宽度
printf("std::vector<%s> %*s%s;\n",
text_char, - ( + strlen(text_char)), "", "m_vec_var"); /*
// 输出的结果如下:
char m_ch_var;
char* m_ch_ptr;
int32_t m_nvar;
int32_t* m_pvar;
std::vector<char> m_vec_var;
*/ // 对于字符串而言,还可以使用"%.*s" 限制输出字符串的最大长度,即:可以将"char", 限制只输出"ch",或者"cha".
printf("%.*s, end.\n", , the_text);
printf("%.*s, end.\n", , the_text);
printf("%.*s, end.\n", , the_text);
printf("%.*s, end.\n", , the_text); /*
// 输出结果如下:
t, end.
th, end.
thi, end.
this is , end.
*/ // 同时在前面再加上一个* 就跟上面的意义一样,设置输出宽度
printf("%*.*s, end.\n", , , the_text);
printf("%*.*s, end.\n", , , the_text);
printf("%*.*s, end.\n", , , the_text);
printf("%*.*s, end.\n", , , the_text); /*
// 输出结果如下:
t, end.
th, end.
thi, end.
this is , end.
*/ // 以上的方法同样可针对浮点数,特别是"%*.*lf",应该特别有用。 return ;
}
printf("%*s\n", 1, ""); 使用"printf();" 的格式化输出动态制定等宽度输出。的更多相关文章
- 与C中printf并列的System.out.printf 用法(转载)
转载地址: https://blog.csdn.net/qq_39017218/article/details/80042287 printf的格式控制的完整格式: % - 0 m.n l或h ...
- C printf按8进制、10进制、16进制输出以及高位补0
; /*按整型输出,默认右对齐*/ printf("%d\n",PrintVal); /*按整型输出,补齐4位的宽度,补齐位为空格,默认右对齐*/ printf("%4d ...
- printf("%d",5.01)和printf("%f",5)的输出结果
printf(); printf("%d\n",5.01); printf(); printf(.f); 输出结果: 看到结果,会感觉非常奇怪.1处怎么会输出0呢?2又为何会显示这 ...
- printf 参数检查 __attribute__((format(printf, 1, 2)))
With GCC, I can specify __attribute__((format(printf, 1, 2))) , telling the compiler that this funct ...
- c++ Cout 输出格式
控制符是在头文件iomanip.h中定义的对象.使用前必须把iomanip.h包含进来 1. I/O的书写格式 I/0流是输入或输出的一系列字节,当程序需要在屏幕上显示输出时,可以使用插入操作符“&l ...
- C语言之顺序结构
该章内容:这章我们学习三大结构之一:顺序结构,它是程序从上往下顺序执行,是程序运行最简单的方式.printf和scanf函数使用和特例是必考知识.本章是考试的重点章节. 学习方法:从简单的顺序结构题目 ...
- 关于printf错用格式化字符串导致double和long double输出错误的小随笔
[题外话] 以前用HUSTOJ给学校搭建Online Judge,所有的评测都是在Linux下进行的.后来为了好往学校服务器上部署,所以大家重新做了一套Online Judge,Web和Judge都是 ...
- C语言printf()函数:格式化输出函数
C语言printf()函数:格式化输出函数 头文件:#include <stdio.h> printf()函数是最常用的格式化输出函数,其原型为: int printf( char ...
- 【Shell脚本学习15】shell printf命令:格式化输出语句
printf 命令用于格式化输出, 是echo命令的增强版.它是C语言printf()库函数的一个有限的变形,并且在语法上有些不同. 注意:printf 由 POSIX 标准所定义,移植性要比 ech ...
随机推荐
- NLTK中的词性
NOUN n,VERB v ,ADJ a, ADV r, ADJ_SAT s NOUN: [('s', ''), ('ses', 's'), ('ves', 'f'), ('xes', 'x' ...
- Linux 数据流重定向
1.三种数据流重定向1)标准输入(stdin):代码为0,使用0<或0<<,其中代码0可以省略2)标准输出(stdout):代码为1,使用1>或1>>,其中代码1可 ...
- Entity Framework只entity与DbContext的分离
说明:以下例子采用的是DB first的模式 在之前的webform开发模式中我们习惯性性的会建立这样的一些类库:Model.DAL.BLL...但是在用了EF以后,我们创建的ADO.NET实体数据模 ...
- mov视频转gif
在mac上用quicktime录屏,得到一个mov视频,想转成gif,试了几个工具,感觉下面这个最好用: http://ezgif.com/video-to-gif 支持重新指定尺寸和帧率,转完gif ...
- 【转】如何让DIV水平和垂直居中
来源:http://blog.163.com/www.wxs_123/blog/static/82784664201321831746921/ 我们在设计页面的时候,经常要把DIV居中显示,而且是相对 ...
- 使用面向对象思想处理cookie
实例:使用面向对象思想处理cookie如果读者对cookie 不熟悉,可以在第七章学习它的使用方法,虽然在那里创建了几个通用函数用于cookie 的处理,但这些函数彼此分离,没有体现出是一个整体.联想 ...
- 关于ttserver, mongodb, couchbase. ssdb ,tair, leveldb的一点使用体验
2年前使用的ttserver,性能很高,支持分布式,但稳定性不足,当存储容量达到亿级的时间经常会出现无法插入的情况,而且不知道是什么原因造成的错误,重启后也无济于事,只好重启开新库. 单库写入性能 2 ...
- 局域网怎么通过IP查看对方MAC
在cmd命令状态查输 入:nbtstat -a IPIP地址就是你所需要查询的IP地址,如192.168.1.200,效果如下图:
- MySQLAdmin用法
MySQLAdmin用法用于执行管理性操作.语法是:shell> mysqladmin [OPTIONS] command [command-option] command ...通过执行mys ...
- [mysql] Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'loser.tank_admin.login_ip' which is not functionally dependent on columns in GROUP BY clause; this is
执行SQL: SELECT login_name,login_ip,sex FROM tank_admin GROUP BY login_name ; 时抛出异常. Expression #2 of ...