众所周知,在int类型变量定义的时候,我们通常都会存放10进制的整数,但如果我们想要存放2、8和16进制的数时,就会发现使用书面写法时。(8进制暂时没有特殊的书面写法)
int a2 = 1101B, b16 = 2FH; //a = 13, b = 47
会报错,而他的正确写法则是
int a = 0b1101, b = 074, c = 0x2F; //b = 60
其中:
0b 是表示2进制数
0 是表示8进制数
0x 是表示16进制数
考点
源代码:
#include <iostream>
#include <cstdio>
#define ll long long
using namespace std;
int main()
{
int a = 100, b = 0xFF, c = 0100;
cout<<a<<" "<<b<<" "<<c;
return 0;
}
题目:
输出:_________
这道题的正确答案是:
100 255 64
其中的坑点不太明显。
c = 0100;
这段语句中很多人都认为在数字前面加一个或多个0都会被编译器忽略掉,不影响输出结果,但其实,这个“0”其实是表示“100”这个数是一个8进制下的一个数,在输出的时候,会将他转成10进制数输出。