printf格式控制的完整格式:
% - 0 m.n l或h格式的字符
对构成格式说明的各项目进行说明。
% :表示格式说明的开始符号,不可缺少。
- :有-表示左对齐输出,省略表示右对齐输出。
)有0 )时表示指定空位为0,省略时表示没有指定空位。
(n ) m是指域名宽度,即对应的输出项目在输出设备中所占的字符数。 n指的是精度。 说明输出实数的小数位数。 如果指定了n,则隐式精度为n=6位。
l或h:l对于整数型指长型,对于实型指双型。 h用于将整数格式字符修改为短整型。
-------------请参阅
格式字符
格式字符指定输出项目的数据类型和输出格式。
(d格式)用于输出十进制整数。 这些用法包括:
%d :以整数数据的实际长度输出。
%md:m是指定输出字段的宽度。 数据位数小于m时,在左端填补空格,大于m时,以实际位数输出。
% LD :输出长数据。
)格式)以无符号的8进制格式输出整数。 长整数可以以“%lo”格式输出。 也可以指定以“%mo”格式输出字段宽度。
示例:
main () )
{ int a=-1;
printf('%d,%o ',a,a );
}
执行结果:-1,177777
程序分析:-1在存储器单元中(作为补码存储) 1111111111111111111 )转换为2、8进制时) 177777 ) 8。
(x格式)以无符号的16进制格式输出整数。 长整数可以以“%lx”格式输出。 也可以指定以“%mx”格式输出字段宽度。
) u格式)以无符号10进制格式输出整数。 长整数可以以“%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 :其中m、n的含义相同,n个字符的输出位于m列范围的左侧,右边填充空格。 nm时,自动取n的值,保证n个字符正常输出。
) f形式)用于以小数形式输出实数(包括单精度、双精度)。 这些用法包括:
%f :不指定宽度,整数部分全部输出小数6位并输出。
%m.nf :输出共占m列,其中有n位小数。 例如,数值宽度比m的左端小来填充空间。
%-m.nf :输出共占n列,其中有n位小数。 例如,如果数字的宽度小于m的右端,则填充空格。
) e格式)以指数形式输出实数。 可以使用以下格式:
%e )数字部分(也称为尾数)输出6位小数,指数部分包含5位或4位。
%m.ne和%-m.ne:m、n和“-”的字符含义与前面相同。 这里,n表示数据数字部分的小数位数,m表示输出数据整体所占的宽度。
) g格式)自动选择f格式或e格式中较短的一个输出,不输出无意义的零。
-------------请参阅
有关printf函数的详细信息:
输出字符“%”时,“格式控制”字符串中必须用连续的2个%表示,如:
printf(%f% )、1.0/3;
输出0.333333%。
-------------请参阅
对于单精度数,使用%f格式输出时,只有前7位是有效数字,小数为6位。
对于双精度数,使用%lf格式输出时,前16位是有效数字,小数为6位。
# # # # # # # # # # # # # # # # # # # # # # # # # #拾遗# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
上级指示
m.n的格式也可以用以下方法表示(例如
char ch[20];
printf('%*.*s/n )、m、n、ch );
前面的*定义整体的宽度,后面的*定义输出的个数。 分别对应于外部参数m和n。 我认为这种方法的优点是可以在语句外通过给参数m和n赋值来控制输出格式。
------------- -请参阅
今天(06.6.9 )看到了可以将输出字符串的长度值代入变量的输出格式) n。 请参见示例:
int slen;
printf(Helloworld%n ),slen );
执行后的变量被分配为11。