格式化输出
使用printf函数格式化输出:
格式控制字符 | 作用 |
---|---|
d | 以十进制格式输出整数 |
o | 以八进制格式输出无符号整数 |
x | 以十六进制格式输出无符号整数 |
u | 以十进制格式输出无符号整数 |
f | 以小数形式输出单精度、双精度浮点数,默认输出到小数点后6位 |
e | 以标准指数形式输出单精度、双精度浮点数,数字部分6位小数 |
c | 以字符形式输出一个字符 |
s | 输出一个以’\0’结尾的字符串 |
// 运行环境VS2017社区版
#include <stdio.h>
#include <iostream> // for system()函数
void pause() {
printf("\n");
system("pause");
}
int main() {
int integer = -10;
printf("%d\n", integer); // 输出-10
printf("%o\n", integer); // 输出37777777766
printf("%x\n", integer); // 输出fffffff6
printf("%f\n", integer); // 输出0.000000
unsigned int unsignedInteger = (unsigned int)(integer);
printf("%d\n", unsignedInteger); // 输出-10
printf("%u\n", unsignedInteger); // 输出4294967286
printf("%e\n", 120.0); // 输出1.200000e+02
pause();
return 0;
}
我们来分析上面的程序的输出结果:
printf(“%o\n”, integer); // 输出37777777766
为什么输出结果是37777777766呢?
上面我们说过,”%o”用来以八进制格式输出无符号整数。我们知道,在计算机里面,整数是以补码的形式存放的。我们写一段代码来观察一下整数在计算机内部的存储方式:
#include <stdio.h>
#include <iostream>
void pause() {
printf("\n");
system("pause");
}
int main() {
int integer = -10;
int integer2 = 4294967286;
pause();
return 0;
}
调试运行上面的这段代码,然后在pause()这一行加一个断点,接着查看局部变量的值(如下图所示):
从上图可知,int类型的十进制数-10与十进制数4294967286在内存中的存放情况是一致的,都是0xfffffff6。当从某数据由int类型强转为unsigned int类型时,该数据在内存中的存放情况不变,这一点可以用下面这段代码来验证:
#include <stdio.h>
#include <iostream>
void pause() {
printf("\n");
system("pause");
}
int main() {
int integer = -10;
unsigned int integer3 = integer;
pause();
return 0;
}
同样的,在pause()的位置设置断点,调试运行,查看局部变量的值:
由此可知,数据由int类型转unsigned int类型,数据的在内存中的存放形式不变。所以上面的“printf(“%o\n”, integer);”输出结果为37777777766 (八进制)也就容易理解了,因为printf函数内部把有符号数-10强转为无符号类型时,把-10转为了无符号数4294967286(因为-10和4294967286在内存中都是以补码形式存放,且内存中存放的补码都为0xfffffff6)。
“printf(“%x\n”, integer); ”输出的就是数据在内存中的补码,即0xfffffff6。
要注意的一点是,“printf(“%f\n”, integer); ”输出结果为0.000000,因为c语言中浮点数在内存中存放的形式和整数存放的形式不一样,故而千万不要乱用”%f”来输出整形数据哦!