C语言里面,输出是调用printf()这个函数,在stdio.h定义在这个头文件中。这里简单总结一下printf函数的几种常见用法。

printf函数原型

printf函数是一个返回值为int类型的函数,返回的值是输出的字符长度。

# include <stdio.h>
int printf(const char *format, ...);

比如下面这个程序,a的值为4。因为输出了123,还有一个换行符,总共四个字符。

#include<stdio.h>
int main(){
    int a=printf("%d\n",123);
    printf("%d",a);
}

常用的格式说明符

C语言里面有浮点型,整形,字符,等类型的数据,那么要输出这些类型的变量,就要使用相应的各式控制符,常用的具体如下表所示。

说明符

输出量


d i

有符号十进制整数

392

u

无符号十进制整数

7235

o

无符号八进制

610

x

无符号十六进制整数

7FA

X

无符号十六进制整数(大写)

7FA

f

十进制浮点数,小写

392.65

F

十进制浮点数,大写

392.65

e

科学表示法(尾数/指数),小写

3.9265 e+2

E

科学表示法(尾数/指数),大写

3.9265 E+2

g

使用最短的表示:%e%f

392.65

G

使用最短的表示:%E%F

392.65

a

十六进制浮点,小写

-0xc.90fep-2

A

十六进制浮点,大写

-0XC.90FEP-2

c

字符

a

s

字符串字符

样本

p

指针地址

8000000

n

没有印刷。


相应的参数必须是指向有符号整数的指针。


到目前为止写入的字符数存储在指定的位置。

%

输出字符%

%

代码示例如下

#include<stdio.h>
int main(){
    printf("%c\n",'a');
    printf("%d\n",123);
    printf("%f\n",123.4567);
    printf("%%\n");
    printf("%s","hello world");
    // …………………… 剩下的照着上面的样例自己试试。
}

补充说明

除了上述格式外,还有一些比较常用的。

%xd

意思是当输出字符总共占x个宽度(一个字符一个宽度,例如数字123456,则是六个字符串宽度)。但输出字符宽度少于x时,用空格补齐,当输出字符多余x个时,按原本内容输出。

#include<stdio.h>
int main(){
   printf("%3d\n",1);
   printf("%3d",123);
}

%0xd

这个用法跟上面%md用法类似,区别在于,当输出不足x位时,则使用0去补齐。

#include<stdio.h>
int main(){
   printf("%03d\n",1);
   printf("%03d",123);
}

%x.mf

这个是控制小数位数的输出格式,m表示输出的小数位数。x用法则跟上面%xd一样。不过这个如果不要求整数部分的位数时,可以省略写成.mf

#include<stdio.h>
int main(){
    printf("%3.4f\n",123.4567);
    printf("%.4f\n",123.4567);
    printf("%4.6f\n",123.4567);

}

%+d、%+f、%+x.mf 等

这个输出格式跟上面的区别在于多了一个+号。在C语言里面,输出数值类型的变量时,如果为正数,是默认省略数字前面的+号。而这里加了+号之后,就可以在输出的时候,带上+号

#include<stdio.h>
int main(){
    printf("%+3.4f\n",123.4567);
    printf("%+d\n",123);
    printf("%+f\n",12113.4567);
}

%-x.mf、%-xd 等

这个输出格式跟上面的区别在于多了一个-号。这个表示左对齐。原本输出时不足x位,则会用空格补齐,不过空格是放在左边的,加了-号之后,空格会补在右边。

#include<stdio.h>
int main(){
    printf("%-3.4f\n",123.4567);
    printf("%-10d\n",12113);
}