目录
printf 函数
包含在 <stdio.h> 头文件中
函数原型:int printf ( const char * format, ... );
将数据以字符串的方式输出至屏幕上
参数:
const char * format(格式) : 想要输出的数据,若其中有占位符(%),那么在后续的附加参数中会依次替换到占位符中
...(附加参数): 根据格式中的占位符,挨个的替换到格式中
这些参数的数量应至少与格式说明符中指定的值数一样多,否者该函数将忽略其他参数
返回值:
成功后,将返回写入的字符总数
如果发生写入错误,则设置错误指示符 (ferror) 并返回负数
使用:
int main() {
printf("玖伍\n");
printf("玖伍刚满%d岁\n",18);
return 0;
}
限制小数点后的最大宽度
当我们使用占位符 %f 打印一个浮点数的时候,想要限制浮点数小数点后最大宽度
例如:
有一个浮点数1.454,我们将它打印的时候只想要小数点后 2 位
% 后面跟上 ——> . +最大宽度
int main(){
float a = 1.455;
printf("%.2f",a);//打印1.45
return 0;
}
细节
小数点的最后一位,会进行四舍五入,例如,1.455 保留小数点 2 位,那么它就会变成 1.46
int main(){
float a = 1.455;
printf("%f.2",a);//打印1.46
return 0;
}
限制整数最小宽度
当我们使用占位符 %d 打印一个整数的时候,想要限制它的最小宽度该怎么做
% 后面跟——> 最小宽度
情况一:
整数宽度 > 最小宽度
例如,12345 限制最小宽度为 4
int main() {
int a = 12345;
printf("%4d",12345);//打印12345,什么也没有做
return 0;
}
什么也没有做
情况二:
整数宽度 < 最小宽度
例如,12345 限制最小宽度为 10
int main() {
int a = 12345;
printf("%10d",12345);//打印:空格空格空格空格空格12345
return 0;
}
那么它除了打印12345以外,还会将其余的空间打印空格
默认情况下,它们都是向右靠齐的
想要让它向左靠齐,那么只需在前面加个符号即可
int main() {
int a = 12345;
printf("%-10d",12345);//打印:12345空格空格空格空格空格
return 0;
}
占位符大全
%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:已输出的字符串数量。该占位符本身不输出,只将值存储在指定变量之中。
%0:八进制整数。
%p:指针。
%s:字符串。
%u:符(unsigned int)。
%x:十六进制整数。
%zd: size_t类型。
%%:输出一个百分号。