在c++++14中,二进制字面量通过以0b或0b开头后跟由0和1组成的数字序列书写,例如0b110011;其支持赋值给int、long、unsigned int等整型变量,并可通过单引号提升可读性,但不适用于浮点数;常见于设置寄存器、定义位掩码与枚举值,且可结合std::bitset用于调试输出。

在C++14中,你可以直接使用二进制字面量来表示整数常量,而不需要再通过十进制、八进制或十六进制转换。这是通过在数字前加上0b或0B来实现的。

例如:

int x = 0b1010; // 表示十进制的10
如何正确书写二进制字面量
从C++14开始,标准支持以二进制形式直接写整型常量。其基本格式是:
立即学习“C++免费学习笔记(深入)”;
- 以
0b或0B开头(两者都可以) - 后跟一串由
0和1组成的数字序列
例如:

auto a = 0b110011; // 十进制为51 auto b = 0B10101010; // 十进制为170
这种写法特别适合处理位掩码、硬件寄存器配置等场景,让代码更具可读性。
支持的数据类型和使用限制
虽然语法上你只能写出整型的二进制字面量,但它们可以被自动推导或赋值给不同类型的变量,比如 int、long、unsigned int 等。
例如:
unsigned int mask = 0b1111'0000; long bigValue = 0b1LL << 20; // 结合移位操作也很常见
需要注意几点:
- 不支持浮点数使用二进制字面量
- 如果数值太大,超出了目标类型的表示范围,会触发编译错误或警告
- 可以使用单引号
'来分隔位组,提升可读性(如0b1100'1100'0011'0011)
常见应用场景和技巧
二进制字面量最常见的用途包括:
- 设置寄存器或标志位:
config |= 0b1000'0000; - 位掩码定义:
#define FLAG_A 0b0000'0001 - 枚举值定义:避免魔法数字,提高可读性
一个实用的小技巧是结合 std::bitset 使用,方便调试输出:
#include#include int main() { unsigned int flags = 0b101010; std::bitset<8> bits(flags); std::cout << bits << "\n"; // 输出: 00101010 }
基本上就这些。掌握这个语法后,在需要按位操作或配置硬件时,能让你的代码更直观清晰。










