printf()
printf()的作用是将参数文本输出到屏幕。它名字里面的f代表format(格式化),表示可以定制输出文本的格式。
占位符
%i
printf()可以在输出文本中指定占位符,所谓“占位符”,就是这个位置可以用其他值代入。
比如我想输出一段内容:“there are 3 people here”
#include <stdio.h>
int main()
{
printf("there are %i people here\n", 3);
return 0;
}
%i就是占位符,表示这个位置的值,要用其他值来替换。占位符的第一个字符一律用%,也就是百分号,第二个字符表示占位符的类型,i可以理解成integer(整数),%i表示这里代入的值必须是一个整数。
printf 是一个预定义的标准库函数,是在标准库的头文件stdio.h定义的。使用这个函数之前,必须在源码文件头部引入这个头文件。
%s
比如我想输出一段内容 “we are family”
···
printf(“we are %s\n”, “family”);
···
%s占位符,表示代入的是一个字符串,s可以理解成string(字符串),所以printf()的第二个参数就必须是字符串。
Q:如果想同时使用两个占位符?
A:
printf("we are %s, we have %i people", "family", 3);
第一个占位符是%s,对应第二个参数"family",第二个占位符是%i,对应第三个参数3
printf()参数与占位符是一一对应关系,如果有n个占位符,printf()的参数就应该有n + 1个。如果参数个数少于对应的占位符,printf()可能会输出内存中的任意值。
比如:
printf("we are %s, we have %i people", "family");
输出结果是
we are family, we have 12993088 people
这显然是不对的。
printf()的占位符有许多种类,与 C 语言的数据类型相对应。下面按照字母顺序,列出常用的占位符,方便查找。
Q: 什么是标准库?
A:
C语言的标准库(standard library)就像是一个工具箱,里边装满了各种现成的小工具(也就是函数),当你写C语言程序的时候,可以直接用这些工具来完成一些常见的任务。因为它们是写入标准的,到底包括哪些功能,应该怎么使用的,都是规定好的,这样才能保证代码的规范和可移植。
不同的功能定义在不同的文件里面,这些文件统称为“头文件”(header file)。如果系统自带某一个功能,就一定还会自带描述这个功能的头文件,比如printf(),scanf()的头文件就是系统自带的stdio.h。头文件的后缀通常是.h。
如果要使用某个功能,就必须先加载对应的头文件,加载使用的是#include命令。这就是为什么使用printf()之前,必须先加载stdio.h的原因。
#include <stdio.h>
以下
%a:十六进制浮点数,字母输出为小写。
%A:十六进制浮点数,字母输出为大写。
%c:字符。
%d:十进制整数。
%e:使用科学计数法的浮点数,指数部分的e为小写。
%E:使用科学计数法的浮点数,指数部分的E为大写。
%i:整数,基本等同于%d。
%f:小数(包含float类型和double类型)。
%g:6个有效数字的浮点数。整数部分一旦超过6位,就会自动转为科学计数法,指数部分的e为小写。
%G:等同于%g,唯一的区别是指数部分的E为大写。
%hd:十进制 short int 类型。
%ho:八进制 short int 类型。
%hx:十六进制 short int 类型。
%hu:unsigned short int 类型。
%ld:十进制 long int 类型。
%lo:八进制 long int 类型。
%lx:十六进制 long int 类型。
%lu:unsigned long int 类型。
%lld:十进制 long long int 类型。
%llo:八进制 long long int 类型。
%llx:十六进制 long long int 类型。
%llu:unsigned long long int 类型。
%Le:科学计数法表示的 long double 类型浮点数。
%Lf:long double 类型浮点数。
%n:已输出的字符串数量。该占位符本身不输出,只将值存储在指定变量之中。
%o:八进制整数。
%p:指针。
%s:字符串。
%u:无符号整数(unsigned int)。
%x:十六进制整数。
%zd:size_t类型。
%%:输出一个百分号。
输出格式
限制宽度
printf()通过格式化字符串可以指定占位符的最小宽度,也就是能够控制输出字段的最少字符数量。如下打印一个整数变量,想确保它在输出时至少占据一定数量的字符空间,不论该数值本身的位数是否达到这个宽度,都可以使用这种方法。
printf("%5d\n", 123); // 输出为 " 123"
这里%5d中的5,指的就是占位符的最小宽度,表示输出的整数值至少会占用5个字符的位置,由于value是123,所以在输出时会在123的左边填充足够的空格,使其总共有5个字符宽。
输出的值默认是右对齐,如果想左对齐的效果
printf("%-5d\n", 123); // 输出为 "123 "
这个功能在创建整齐排列的报表或者格式化输出时非常有用。
总是显示正负号
默认情况下,printf()不对正数显示+号,只对负数显示-号。如果想让正数也输出+号,可以在占位符的%后面加一个+
printf("%+d\n", 12345); // +12345
%+d可以确保输出的数值,总是带有正负号。
限定小数位数
比如希望小数点后面只保留两位,占位符可以写成%.2f
printf("%f\n", 0.5); // 0.500000
⬇️
printf("%.2f\n", 0.5); // 0.50
结合限制宽度一起使用
printf("%6.2f\n", 0.5); // " 0.50"
另外,最小宽度和小数位数这两个限定值,都可以用*代替,通过printf()的参数传入。
printf("%*.*f\n", 6, 2, 0.5); // " 0.50"
上面示例中,%*.*f的两个星号通过printf()的两个参数6和2传入。
等同于
printf("%6.2f\n", 0.5); // " 0.50"
对字符串的控制
输出部分字符串,%.[m]s指定输出的长度,其中[m]代表一个数字,表示所要输出的长度。
printf("%.5s\n","hello world"); // hello