c++逻辑与运算符
C++ Logical AND Operator
我试图使用逻辑与运算符,但我得到一些意想不到的行为。
#include <iostream>
using namespace std;
int main() {
unsigned flags = 0;
cout << "flags = " << flags << endl;
for(int i=0; i<3; ++i) {
flags &= (1 << i);
cout << "Anding with " << (1 << i) << endl;
cout << "flags = " << flags << endl;
}
return 0;
}
实际输出:flags = 0
Anding with 1
flags = 0
Anding with 2
flags = 0
Anding with 4
flags = 0
预期输出:flags = 0
Anding with 1
flags = 1
Anding with 2
flags = 3
Anding with 4
flags = 7
注意,我可以通过简单地替换&我的程序中有+。但我想知道我在这里做错了什么?
这是位和…人们认为a & b
的意思是"返回a
的所有比特和b
的所有比特……"它不是。表示"返回 a
和 b
中设置的位"。
如果a为1,b为2,则二进制表示为01
和10
…没有共同点!结果当然是0。
您需要使用的是按位或。a | b
表示"返回 a
或 b
中设置的所有位。
如果a为1,b为2,则二进制表示为01
和10
,因此结果为11
或您期望的3。
将这些操作理解为集合操作"交集"answers"并集",而不是二元操作"和"answers"或",可能会有所帮助。
您混淆了|
和&
。您期望的结果对应于以下迭代:
flags |= (1 << i);
|=
中的按位或将"添加"位到您的bitset flags
中,而按位与只能删除位。
相关文章:
- 为什么比较运算符如此快速
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 增量运算符与后缀混淆
- 一个关于在C++中重载布尔运算符的问题
- 运算符C++ "delete []"仅删除 2 个前值
- 模板类无法识别友元运算符
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 关闭||运算符优化
- 通过继承类使用来自不同命名空间的运算符
- C++Cast运算符过载
- 如何使用AngelScript注册SFML Vector2运算符
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 布尔比较运算符是如何在C++中工作的
- 重载运算符new[]的行为取决于析构函数
- 如何防止clang格式在流运算符调用之间添加换行符<<