0

0

c++中的位运算怎么操作_c++位运算符与应用实例

尼克

尼克

发布时间:2025-10-28 15:35:01

|

365人浏览过

|

来源于php中文网

原创

C++位运算通过操作二进制位提升效率,适用于底层编程与算法优化。1. 包含6种运算符:&(按位与)、|(按位或)、^(异或)、~(取反)、(右移),用于整型数据的位级操作。2. 典型应用有:判断、设置、清除、翻转特定位,利用左移右移实现乘除2的幂,异或交换两数,n & (n-1)统计1的个数,以及用整数位表示多个状态标志,提高空间与操作效率。熟练掌握可写出高效简洁代码。

c++中的位运算怎么操作_c++位运算符与应用实例

位运算是C++中直接对整数的二进制位进行操作的技术,效率高,常用于底层编程、算法优化和状态管理。掌握位运算不仅能提升程序性能,还能简化某些逻辑处理。

1. C++中的位运算符种类

C++提供了6种基本的位运算符,适用于整型数据(如int、char等):

  • &:按位与。两个对应位都为1时结果为1。
  • |:按位或。两个对应位有一个为1时结果为1。
  • ^:按位异或。两个对应位不同时为1。
  • ~:按位取反。每一位0变1,1变0(包括符号位)。
  • :左移。将二进制位整体向左移动n位,右边补0。
  • >>:右移。将二进制位整体向右移动n位,左边补符号位(算术右移)或0(逻辑右移,取决于编译器和类型)。

例如:

int a = 5;     // 二进制: 00000101
int b = 3;     // 二进制: 00000011

cout << (a & b) << endl; // 输出: 1 (00000001) cout << (a | b) << endl; // 输出: 7 (00000111) cout << (a ^ b) << endl; // 输出: 6 (00000110) cout << (~a) << endl; // 输出: -6(补码表示) cout << (a << 1) << endl; // 输出: 10 (00001010) cout << (a >> 1) << endl; // 输出: 2 (00000010)

2. 常见应用场景与实例

位运算在实际开发中有许多巧妙用途,以下是一些典型例子。

立即学习C++免费学习笔记(深入)”;

判断某位是否为1

使用&配合左移判断第n位是否为1(从0开始计数)。

bool isBitSet(int num, int n) {
    return (num & (1 << n)) != 0;
}
// 示例:检查5的第0位是否为1
isBitSet(5, 0); // true (5的二进制末位是1)

设置某位为1

使用|和左移将第n位置1。

int setBit(int num, int n) {
    return num | (1 << n);
}
// 将6(0110)的第0位置1 → 7(0111)
setBit(6, 0); // 返回7

清除某位为0

使用& ~(1 将第n位清零。

int clearBit(int num, int n) {
    return num & ~(1 << n);
}
// 将7(0111)的第0位清零 → 6(0110)
clearBit(7, 0); // 返回6

翻转某一位

^实现位的切换(0变1,1变0)。

int toggleBit(int num, int n) {
    return num ^ (1 << n);
}
// 翻转5(101)的第1位 → 7(111)
toggleBit(5, 1); // 返回7

快速乘除2的幂

左移相当于乘以2,右移相当于整除2。

int x = 8;
x << 1; // 相当于 x * 2 = 16
x >> 1; // 相当于 x / 2 = 4
注意:右移负数时行为依赖系统(通常为算术右移)。

交换两个数(不用临时变量)

利用异或特性:a ^ a = 0a ^ 0 = a

int a = 5, b = 3;
a = a ^ b;
b = a ^ b; // b = (a^b)^b = a
a = a ^ b; // a = (a^b)^a = b
// 此时a=3, b=5
虽然有趣,但实际开发中不推荐,可读性差且现代编译器优化已足够好。

统计二进制中1的个数(汉明重量)

常用技巧:每次执行n & (n-1)会清除最右边的1。

int countOnes(int n) {
    int count = 0;
    while (n) {
        n &= (n - 1);
        count++;
    }
    return count;
}
// countOnes(7) → 3(111有三个1)

应用:状态标志管理

用一个整数表示多个布尔状态,节省空间且操作高效。

const int FLAG_READ    = 1 << 0;  // 0001
const int FLAG_WRITE   = 1 << 1;  // 0010
const int FLAG_EXECUTE = 1 << 2;  // 0100

int permissions = 0; permissions |= FLAG_READ; // 添加读权限 permissions |= FLAG_WRITE; // 添加写权限

if (permissions & FLAG_READ) { // 检查是否有读权限 cout << "Read allowed" << endl; }

基本上就这些。位运算看似低级,但在特定场景下非常有用。理解其原理后,能写出更高效、更简洁的代码。关键是熟悉二进制表示和每种运算符的行为特点。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1427

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

221

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

69

2025.10.17

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

510

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

46

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

174

2025.08.29

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

378

2023.08.14

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 5.2万人学习

C 教程
C 教程

共75课时 | 3.6万人学习

C++教程
C++教程

共115课时 | 9.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号