首页 > 后端开发 > C++ > 正文

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

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

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

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

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

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

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

例如:

int a = 5;     // 二进制: 00000101
int b = 3;     // 二进制: 00000011
<p>cout << (a &amp; 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)</p>
登录后复制

2. 常见应用场景与实例

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

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

判断某位是否为1

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

bool isBitSet(int num, int n) {
    return (num &amp; (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

使用&amp; ~(1 << n)将第n位清零。

算家云
算家云

高效、便捷的人工智能算力服务平台

算家云37
查看详情 算家云
int clearBit(int num, int n) {
    return num &amp; ~(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 &amp; (n-1)会清除最右边的1。

int countOnes(int n) {
    int count = 0;
    while (n) {
        n &amp;= (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
<p>int permissions = 0;
permissions |= FLAG_READ;      // 添加读权限
permissions |= FLAG_WRITE;     // 添加写权限</p><p>if (permissions &amp; FLAG_READ) { // 检查是否有读权限
cout << "Read allowed" << endl;
}</p>
登录后复制

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

以上就是c++++中的位运算怎么操作_c++位运算符与应用实例的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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