Complement of unsigned int
Complement of unsigned int
我最近看到了下面一段代码:
unsigned short int a = 0xffff;
~a;
printf("%x", a);
输出为:
0xffff
根据我所学到的,~a
应该翻转a的所有位,给出以下结果:
0x0000
为什么输出是0xffff
呢?
你忘了把结果赋值给a,就像
int a = 3;
a + 2;
printf ("%dn", a);
将打印3而不是5。
因为您没有将其分配给a
,值只是被丢弃,尝试
a = ~a;
与大多数其他操作符一样,~不会就地修改变量,而是"返回"修改后的值作为结果。想想一元减号:如果你想改变一个变量的符号,你不用
-a;
,
a=-a;
同样适用于位not操作符;要得到预期的结果,执行以下命令:
a=~a;
相关文章:
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 错误:隐式转换更改符号:'int'到'unsigned long'
- 定义 uint= "unsigned int" 没有像我在 Visual Studio 中使用 nvcc 时预期的那样应用
- 对 '(const Y) (int&, std::mersenne_twister_engine<long unsigned int,
- 错误:'class std::unique_ptr<std::set<long unsigned int> >'没有名为 'size' 的成员
- 正确语法,用于统一初始化名称中带有空格的类型的临时,如unsigned int
- "1L << count"是什么意思?如何使用超出"unsigned long long int? "范围的语句编号打印?
- C++ - 从 "int" 到 "unsigned char" 的缩小转换无效
- 按值对 std::unordered_map<std:::string, std::atomic<unsigned int>> 进行排序
- 编译Qt项目给出了对运算符delete(void*,unsigned int)的未定义引用
- 错误:无法将'uint8* {aka unsigned int*}'转换为"常量emxArray_uint8_T*"?
- memcpy unsigned char to int
- 没有匹配函数来调用"std::basic_ofstream<char>::write(std::string*, long long unsigned int)"
- 初始化unsigned int至0
- 为什么"unsigned int" + "unsigned int"返回"unsigned int"?
- C++模板比 int->unsigned 转换更好?
- 错误:从'int'分配给'_List_iterator<unsigned int,unsigned int &,unsigned int *>'
- 请求在"num"中请求成员"push_back",其非类类型为"int[((unsigned int)((int)n))]"