C语言常用的输出格式控制

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);
}

猜你喜欢

转载自blog.csdn.net/qq_43058685/article/details/108370591