%d:十进制的整数
%u:无符号整数
%ld:长整数
%s:字符串
%c:字符
%g:不包含0的浮点
%f:浮点数
%p:内存地址
%x:十六进制的整数
%o:八进制的整数
ps:
%f 和 %lf 用法的区别:
%f只能用于printf输出double类型, %lf用于scanf("%lf“),输出double类型
printf的%f说明符的确既可以输出float型又可以输出double型。根据“默认参数提升”规则(在printf这样的函数的可变参数列表中,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到双精度数。参见问题15.2。(严格地讲,%lf在printf下是未定义的,但是很多系统可能会接受它。要确保可移植性,就要坚持使用%f。)参见问题12.15和15.2。对于scanf,情况就完全不同了,它接受指针,这里没有类似的类型提升。(通过指针)向float存储和向double存储大不一样,因此,scanf区别%f和%lf。