C语言中 scanf 和 printf 的小要点

1 scanf_s需指定%c 个数
h short
l long关键字
* 不赋给任何值
W 指定读入宽度


转换字符
a 读浮点值(c99)
A 读浮点值(c99)
c 读单字符
d 读十进制数
i 读十进制\八进制\十六进制整数
e 读浮点数
E 读浮点数
f 读浮点数
F 读浮点数(c99)
g 读浮点数
G 读浮点数
o 读八进制数
s 读字符串
x 读十六进制数
X 读十六进制数
p 读指针值
n 至此已读入值的等价字符数
u 无符号十进制整数
[] 扫描字符集合
% 读%符号
2 printf
Format %[flags][width][.prec][F][N][h][i]type
转义字符
type
d\i int
o unsigned int(o)
u unsigned int(d)
x\X unsigned int(h)
f float\double 缺省精度为小数点后六位
e\E double(科学计数法+e\E) 只输出7位有效数字
g\G double(F\E最短的,四位小数) 只输出六位有效数字
c char 当接受值为字符串时打印第一个字符,可以把输入的数字按ASCII转换为对应字符
s\S char*\wchar_t*
p void*(h)
% %


flags
 (空格) 右对齐,输出值为负时加上-
- 左对齐
+ 在数字前增加符号+或-(随数字本身)
0 将输出的前面补上0
# o "0" x "0x" X "0X"
e E f g G 一定使用小数点
g G 尾部0保留
width 
用于控制显示数值的宽度
转换结果宽于字段宽度,将拓展字段以包含
小的精度可能发生截断
prec 0 缺省精度
d\o\x\X\i\u 最少数字显示位数
e\f\E 转换的技术字符后的最少数字显示位数
g\G 转换的最大有效数字位数
s 转换中的字符串最大打印字节数目


F\N\h\l
F 远指针
N 近指针
h 短整型
l 长整型


printf 返回值 实际控制输出的字符数
注:远(far)指针


远指针不是让编译程序把程序数据段地址作为指针的段地址部分,而是把指针的段地址与指针的偏移量直接存放在指针内。因此,远指针是由4 个字节构成。它可以指向内存中的任一目标,可以用于任一编译模式,尽管仅在紧凑、大和巨模式下远指针才是缺省的数据指针。因为远指针的段地址在指针内,熟悉80X86 汇编语言的人都知道,这意味着每次使用远指针时都需要重新装载段寄存器,这显然会降低速度。
2远指针与近指针区别


近指针是16位的指针,它只表示段内的偏移地址,因而只能对64k字节数据段内地址进行存取。
如 char near *p;
p=(char near *)0xffff;
远指针是32位指针,它表示段地址:偏移地址,如定义远程指针p指向B500段的2号地址,即B500:0002,则可写作:
char far *p;
p=(char far *)0xB5000002;

因此,远指针可以进行跨段寻址,可以访问整个内存的地址。

注:float精度 6-7位指数范围-127-+128

double 精度 15-16位指数范围-1023-+1024

注:转义字符 

通用转义字符 \ooo(8进制) \xddd(16进制)(需区分终端输出和文本输出)

不可打印字符\特殊字符 都用转义字符书写

不可打印字符
换行符 \n 终端输出\n即可,文本文件中输出Lunix"\n" Windows "\n\r" Mac "\r" 
水平制表符 \t 占8列,用于将光标跳到[Tab]键的下一个输出区
纵向制表符 \v 后面的字符从下一行开始输出,且开始的列数为'v'前一个字符所在列后面一列
退格符 \b
回车符 \r 光标回到本行行首,可能覆盖之前的内容
进纸符 \f 清空屏幕再次输出
退格符 \b 
报警符 \a
特殊字符
疑问号 \?
单引号 \'
双引号 \"
反斜杠 \\

你可能感兴趣的:(printf)