C语言中 scanf 和 printf 的小要点

时间:2025-01-19 11:03:44

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

特殊字符

疑问号 \?

单引号 \'

双引号 \"

反斜杠 \\