C语⾔中printf格式化输出函数
⽤法:
  int printf(const char *format,[argument]);
  format 参数输出的格式,定义格式为:
  %[flags][width][.perc] [F|N|h|l]type
  规定数据输出⽅式,具体如下:
  1.type 含义如下:
  d 有符号10进制整数
  i 有符号10进制整数
  o 有符号8进制整数
  u ⽆符号10进制整数
  x ⽆符号的16进制数字,并以⼩写abcdef表⽰
  X ⽆符号的16进制数字,并以⼤写ABCDEF表⽰
  F/f 浮点数
  E/e ⽤科学表⽰格式的浮点数
  g 使⽤%f和%e表⽰中的总的位数表⽰最短的来表⽰浮点数 G 同g格式,但表⽰为指数
  c 单个字符
  s 字符串
  % 显⽰百分号本⾝
  p 显⽰⼀个指针,near指针表⽰为:XXXX
  far 指针表⽰为:XXXX:YYYY
  n 相连参量应是⼀个指针,其中存放已写字符的个数
  2.flags 规定输出格式,取值和含义如下:
  ⽆右对齐,左边填充0和空格
  - 左对齐,右边填充空格
  + 在数字前增加符号 + 或 -
  ⼀个空格只对负数显⽰符号
  # 当type=c,s,d,i,u时没有影响
  type=o,x,X时,分别在数值前增加'0',"0x","0X"
  type=e,E,f时,总是使⽤⼩数点
  type=g,G时,除了数值为0外总是显⽰⼩数点 3.width ⽤于控制显⽰数值的宽度,取值和含义如下n(n=1,) 宽度⾄少为n位,不够以空格填充
  0n(n=1,) 宽度⾄少为n位,不够左边以0填充 * 格
  式列表中,下⼀个参数还是width 4.prec ⽤于控制⼩数点后⾯的位数,取值和含义如下:
  ⽆按缺省精度显⽰
  0 当type=d,i,o,u,x时,没有影响
  type=e,E,f时,不显⽰⼩数点
  n(n=1,) 当type=e,E,f时表⽰的最⼤⼩数位数
  type=其他,表⽰显⽰的最⼤宽度 .*
  格式列表中,下⼀个参数还是width
  5.F|N|h|l 表⽰指针是否是远指针或整数是否是长整数
  F 远指针
  n 近指针
  h短整数或单精度浮点数
  l 长整数或双精度浮点数
  1.⼀般格式
  printf(格式控制,输出表列)
  例如:printf("i=%d,ch=%c/n",i,ch);
  说明:
  (1)“格式控制”是⽤双撇号括起来的字符串,也称“转换控制字符串”,它包括两种信息:
  ①格式说明:由“%”和格式字符组成,它的作⽤是将输出的数据转换为指定的格式输出。
  ②普通字符,即需要原样输出的字符。
  (2)“输出表列”是需要输出的⼀些数据,可以是表达式
  (3)printf函数的⼀般形式可以表⽰为
  printf(参数1,参数2,……,参数n)
  功能是将参数2~参数n按参数1给定的格式输出
  2.格式字符(9种)
  (1)d(或i)格式符。⽤来输出⼗进制整数,有以下⼏种⽤法:
  ①%d,按整型数据的实际长度输出。
  ②%md,m为指定的输出字段的宽度。如果数据的位数⼩于m,则左端补以空格,若⼤于m,则按实际位数输出。
  ③%ld(%mld 也可),输出长整型数据。
  例如:long a=123456;
  printf("%ld",a);
  (2)o格式符,以⼋进制数形式输出整数。格式:%o,%mo,%lo,%mlo都可。
  (3)x(或X)格式符,以⼗六进制数形式输出整数。格式:%x,%mx,%lx,%mlx都可。
  (4)u格式符,⽤来输出unsigned型数据,即⽆符号数,以⼗进制数形式输出。格式:%u,%mu,%lu都可。
  参见:li4-3.c/*⽆符号数据的输出*/
  (5)c格式符,⽤来输出⼀个字符。格式:%c,%mc都可。
  (6)s格式符,⽤来输出⼀个字符串。格式:%s,%ms,%-ms,%m.ns,%-m.ns都可。
  参见:li4-5.c /*字符串的输出*/
  (7)f格式符,⽤来输出实数(包括单、双精度),以⼩数形式输出。格式:%f,%m.nf,%-m.nf都可。
  注意:单精度实数的有效位数⼀般为7位,双精度为16位。
  参见:li4-6.c/*输出单精度实数时的有效位数*/
  li4-7.c/*输出双精度实数时的有效位数*/
  li4-8.c/*输出实数时指定⼩数位数*/
  (8)e(或E)格式符,以指数形式输出实数。格式:%e,%m.ne,%-m.ne都可。
  (9)g(或G)格式符,⽤来输出实数,它根据数值的⼤⼩,⾃动选f格式或e格式(选择输出时占宽度较⼩的⼀种)。
  3.说明
  (1)除了X、E、G(⽤⼤写字母表⽰)外,其他格式字符必须⽤⼩写字母;
  (2)“格式控制”字符串内可以包含转义字符;
  (3)如果想输出字符“%”,则应该在“格式控制”字符串中⽤连续两个%表⽰,如:
  printf("%f%%",1.0/3);
  (4)格式字符表参见下表
  表4.1 printf格式字符
  格式字符说明
  d,i 以带符号的⼗进制形式输出整数(正数不输出符号)
  o 以⼋进制⽆符号形式输出整数(不输出前导符0)
  x,X 以⼗六进制⽆符号形式输出整数(不输出前导符0x),⽤x则输出⼗六进制数的a~f时以⼩写形式输出,⽤X时,则以⼤写字母输出  u 以⽆符号⼗进制形式输出整数
  c 以字符形式输出,只输出⼀个字符
  s 输出字符串
  f 以⼩数形式输出单、双精度数,隐含输出6位⼩数
  e,E 以指数形式输出实数
  g,G 选⽤%f或%e格式中输出宽度较短的⼀种格式,不输出⽆意义的0
  表4.2 printf的附加格式说明字符
  字符
  说明
  字母l
  ⽤于长整型整数,可加在格式符d、o、x、u前⾯
  m(代表⼀个正整数)
  数据最⼩宽度
  n(代表⼀个正整数)
  对实数,表⽰输出n位⼩数;对字符串,表⽰截取的字符个数
  -
  输出的数字或字符在域内向左靠
printf 命令
  ⽤途
  写格式化输出。
  语法
  printf Format [ Argument ... ]
  描述
  printf 命令转换、格式化并写 Argument 参数到标准输出。Argument 参数是由 Format 参数控制格式化的。格式化输出⾏不能超出LINE_MAX 字节长度。
  下列环境变量影响 printf 命令的执⾏:
  LANG 在 LC_ALL 和相应的环境变量(以 LC_ 开头)没有指定语⾔环境时,确定语⾔环境编⽬使⽤的语⾔环境。
  LC_ALL 确定⽤于覆盖由 LANG 或其它任何 LC_ 环境变量设置的任何语⾔环境编⽬值的语⾔环境。
  LC_CTYPE 确定把⽂本字节数据顺序解释为字符的语⾔环境;例如,单⼀字节对应多字节字符的参数。
  LC_MESSAGES 确定写消息使⽤的语⾔。
  LC_NUMERIC 确定数字格式编排的语⾔环境。此环境变量影响使⽤ e、E、f、g 和 G 转换字符编写的数字的格式。
  Format 参数是包含三种对象类型的⼀个字符串:
  * ⽆格式字符复制到输出流。
  * 转换规范,每个规范导致在值参数列表中检索 0 个或更多个项。
  * 以下转义序列。在复制到输出流时,这些序列导致它们的相关操作在有此功能的设备上显⽰:
  // 反斜杠
  /a 警告
  /b 退格
  /f 换页
  /n 换⾏
  /r 回车
  /t 跳格
  /v 垂直跳格
  /ddd ddd 是 1、2 或 3 位⼋进制数字。这些转义序列作为由⼋进制数指定的具有数字值的字节显⽰。
  Argument 参数是⼀个或多个字符串的列表,它在 Format 参数的控制下被写到标准输出。
  Format 参数在必要的情况下会经常重新使⽤以满⾜ Argument 参数。将好像提供了空字符串 Argument ⼀样评估任何额外的 c 或者 s 转换规范;其它额外转换规范将好像提供了 0 Argument ⼀样评估。此处 Format 参数不包含转换规范仅出现 Argument 参数,结果是不确定的。
  每个 Format 参数中的转换规范都具有如下顺序的语法:
  1. % (百分号)。
  2. 零或更多的选项,修改转换规范的含义。选项字符和它们的含义是:
  - 转换结果在字段中左对齐。
  + 符号转换结果常以符号(+ 或者 -)开始。
  空格如果符号转换的第⼀个字符不是符号,结果的前缀将是空格。如果空格和 + 选项字符都显⽰,则忽略空格选项字符。
  # 此选项指定值转换到备⽤格式。对于 c、d、i, u 和 s 转换,选项没有作⽤。对于 o 转换,它增加精度来强制结果的第⼀数字是 a、
0(零)。对于 x 和 X 转换,⾮零结果分别具有 0x 或 0X 前缀。对于 e、E、 f、g 和 G 转换,结果通常包含基数字符,即使基数字符后没有数字。对于 g 和 G 转换,结尾零不象通常⼀样除去。
  0 对于 d、i、o、 u、x、e、 E、f、g 和 G 转换,前导零(跟在符号或底数的后⾯)⽤于填充字段宽度,将不⽤空格填充。如果显⽰
0(零)和 -(减号)选项,0(零)选项被忽略。对于 d、i、o、u、x 和 X 转换,如果指定精度,0(零)选项将被忽略。
  注:
  其它转换,没有定义其⾏为。
  3. 可选的指定最⼩值字段宽度的⼗进制数字字符串。如果转换值字符少于字段宽度,该字段将从左到右按指定的字段宽度填充。如果指定了左边调整选项,字段将在右边填充。如果转换结果宽于字段宽度,将扩展该字段以包含转换后的结果。不会发⽣截断。然⽽,⼩的精度可能导致在右边发⽣截断。
  4. 可选的精度。精度是⼀个.(点)后跟⼗进制数字字符串。如果没有给出精度,按 0(零)对待。精度指定:
  * d、o、i、 u、x 或 X 转换的最少数字显⽰位数。
  * e 和 f 转换的基数字符后的最少数字显⽰位数。
  * g 转换的最⼤有效数字位数。
  * s 转换中字符串的最⼤打印字节数⽬。
  5. 指⽰要应⽤的转换类型的⼀个字符,例如:
  % 不进⾏转换。打印⼀个 %(百分号)。
c语言char的用法  d, i 接受整数值并将它转换为有符号的⼗进制符号表⽰法。精度指定显⽰的最⼩数字位数。如果值转换后可以⽤更少的位数来表⽰,将使⽤前导零扩展。缺省精度是 1。精度为零的零值转换的结果是空字符串。⽤零作为前导字符来指定字段宽度,导致⽤前导零填充字段宽度值。
  o 接受整数值并将它转换为有符号的⼋进制符号表⽰法。精度指定显⽰的最⼩数字位数。如果值转换
后可以⽤更少的位数来表⽰,将使⽤前导零扩展。缺省精度是 1。精度为零的零值转换的结果是空字符串。⽤零作为前导字符来指定字段宽度,导致⽤前导零填充字段宽度值。不⽤⼋进制值表⽰字段宽度。
  u 接受整数值并将它转换为⽆符号的⼗进制符号表⽰法。精度指定显⽰的最⼩数字位数。如果值转换后可以⽤更少的位数来表⽰,将使⽤前导零扩展。缺省精度是 1。精度为零的零值转换的结果是空字符串。⽤零作为前导字符来指定字段宽度,导致⽤前导零填充字段宽度值。
  x, X 接受整数值并将它转换为⼗六进制符号表⽰法。字母 abcdef ⽤于 x 转换,字母 ABCDEF ⽤于 X 转换。精度指定显⽰的最⼩数字位数。如果值转换后可以⽤更少的位数来表⽰,将使⽤前导零扩展。缺省精度是 1。精度为零的零值转换的结果是空字符串。⽤零作为前导字符来指定字段宽度,导致⽤前导零填充字段宽度值。
  f 接受浮点或者双精度值并将它转换为⼗进制符号表⽰法,格式为 [-] ddd.ddd。基数字符(在这⾥显⽰为⼗进制点)后的数字位数等于规定的精度。 LC_NUMERIC 语⾔环境编⽬确定在这个格式中使⽤的基数字符。如果不指定精度,则输出六个数字。如果精度是 0(零),将不显⽰基数字符。