#include <stdio.h>int main(){ printf("%*.*d\n",-6,7,20000); printf("%*.*d\n",5,2000); return 0;}
输出:
0020000 2000
我不明白printf如何解释格式说明符*. *?
在第一次调用printf()时,后面的7是否会覆盖前者-6?那么输出宽度的大小变为7?
解决方法@H_403_15@ *之前的论点.是字段宽度和*之后的参数.是精度.字段宽度是转换后输出的最小字节数;如果将产生更少的字节,则输出将被填充(默认情况下,左侧带有空格,但左侧填充和右侧空间填充也是选项,由标志控制). *表示宽度的负参数被解释为带有 – 标志的相应正值,它将填充向右移动(即左对齐字段).
另一方面,精度具有根据所执行的转换而变化的含义.消极精度被视为根本没有指定精度.对于整数,它是要生成的最小位数(不是总输出);如果生成的数字较少,则向左添加零.显式精度为0会导致值为0时不生成数字(而不是生成单个0).对于字符串,精度限制输出字节数,必要时截断字符串(并允许更长,非空终止的输入数组).对于浮点说明符,精度控制打印的位数,在小数点后(对于%f)或总有效位置(对于其他格式).
在你的例子中:
printf("%*.*d\n",20000);
这里的字段是左对齐的(右边的填充),最小宽度为6,但是字段最终会变宽,所以忽略宽度. 7的精度强制整数输出至少为7位,因此最终将0020000作为已转换的字段内容,已超出宽度.
在另一个:
printf("%*.*d\n",2000);
字段宽度为5,默认右对齐;填充左侧有空格.负精度被忽略,就好像没有指定一样,因此转换后的字段内容是2000,只有4个字节,最多填充5个字节以通过单个前导空格填充宽度.
总结以上是内存溢出为你收集整理的c – %*.* d如何在printf()中工作?全部内容,希望文章能够帮你解决c – %*.* d如何在printf()中工作?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)