前言
在我们以后接触到更多知识点时,类型这种东西其实也就不神秘了,我们在学习操作系统时,经常会见到各种各样的类型,如pid_t、in_port_t、int32_t、int16_t等等,这种一般都是经过 typedef 的,其实很多时候我们遇到不认识的类型时,就可以看其是否是经过 typedef ,再进行格式化输出,但如果大家是学C++的同学,就不用担心了,C++的cout可以自动识别类型,其底层其实是做了运算符重载和函数重载的。
一、printf 占位符汇总
1、整型家族
(1)【十进制】【整型】(有符号)
占位符 | 含义 |
%d | int 、char(输出ASCII值) |
%i | 输出有符号的十进制整数 (在scanf中,%i可以将八进制数字和十六进制数字转换成十进制数字输出) |
%hd | short |
%ld | long int |
%lld | long long int |
(2)【十进制】【整型】(无符号)
占位符 | 含义 |
%zd | size_t |
%u | unsigned int |
%llu | unsigned long long int |
%lu | unsigned long int |
(3)【八进制】【整型】
占位符 | 含义 |
%o | 以八进制格式输出 int |
%ho | 以八进制格式输出 short int |
%lo | 以八进制格式输出 long int |
%llo | 以八进制格式输出 long long int |
(4)【十六进制】【整型】
占位符 | 含义 |
%x | 以十六进制格式输出 int |
%hx | 以十六进制格式输出 short int |
%lx | 以十六进制格式输出 long int |
%llx | 以十六进制格式输出 long long int |
2、浮点型家族【here】
占位符 | 含义 |
%f | float |
%lf | double |
%Lf | long double |
%e | 使⽤科学计数法的浮点数,指数部分的 e 为⼩写 |
%E | 使⽤科学计数法的浮点数,指数部分的 E 为⼤写 |
%Le | 科学计数法表⽰ long double |
%g | 6个有效数字的浮点数; 整数部分⼀旦超过6位,就会⾃动转为科学计数法,指数部分的 e为⼩写 |
%G | 等同于 %g ,唯⼀的区别是指数部分的 E 为⼤写 |
%a | ⼗六进制浮点数,字⺟输出为⼩写 |
%A | ⼗六进制浮点数,字⺟输出为⼤写 |
3、字符型家族
占位符 | 含义 |
%c | char |
%s | 字符串 |
4、特殊打印格式
占位符 | 含义 |
%% | 输出⼀个百分号 |
%p | 打印地址(一个十六进制的数) |
%n | 已输出的字符串数量。 该占位符本⾝不输出,只将值存储在指定变量之中 |
二、占位符讲解
1、 八进制格式化打印
不输出前缀0———%o
输出前缀0 ————%#o
八进制数例如:0123,0234,0345,03等前缀是0的数
若想自己定义变量为八进制数字:int x = 01234567; 0开头,后面数字0~7之间;
int a = 0123;printf("%o\n", a);printf("%#o\n", a);
2、十六进制格式化打印
打印十六进制形式
不输出前缀0x———%x , %X
输出前缀0x————%#x,%#X
十六进制数例如:0x11223344, 0X11, 0x221c 等前缀是0x和0X的数
若想自己定义变量为八进制数字:
int x = 0x123a; 0开头,后面数字0~9,a~f之间(a为10,f为15)
#include <stdio.h>int main(){ int x= 0x19adf; printf("%#x\n", x); printf("%x\n", x); return 0;}
3、科学计数法 格式化打印
1. 科学计数法表示的浮点数(小写字母)———%e
2. 科学计数法表示的浮点数(大写字母)———%E
double a = 100.23;printf("%e\n", a);printf("%E\n", a);
4、特殊打印格式(%p、%n)
(1) %p
打印地址———%p(16进制显示)
int a = 100;printf("%p\n", &a);
(2) %n
%n 用来统计printf在%n之前打印的字符个数;%n不会打印出内容;
具体看这个博客:%n在C语言总的意思-CSDN博客
#include <stdio.h>int main(){ int b; printf("helloworld %n12345\n", &b); printf("%d\n", b); return 0;}
三、printf 输出格式
1、限制输出的宽度 - 【%m* 】(* 表示占位符 )
printf 允许限定占位符的最小宽度
m的情况 | 输出格式表示 |
m为正数 | 右对齐 |
m为负数 | 左对齐 |
m < 输出的位数 | 原样输出 |
m > 输出的位数 | 用空格补齐 |
%m.nf | n 表示小数的位数 |
%0m* | 用0补齐 |
2、限制小数的位数 - 【%.nf】
3、总是显示正负号 - 【%+ *】(* 表示占位符)