从C语言的角度重构数据结构系列(十三)-位运算

Posted 文宇肃然

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了从C语言的角度重构数据结构系列(十三)-位运算相关的知识,希望对你有一定的参考价值。

位运算简介

位运算

位运算就是基于整数的二进制表示进行的运算。由于计算机内部就是以二进制来存储数据,位运算是相当快的。

基本的位运算共6 种,分别为按位与、按位或、按位异或、按位取反、左移和右移。

运算 运算符 数学符号表示 解释
& &、and 只有两个对应位都为 1 时才为1
| |、or 只要两个对应位中有一个1  时就为1
异或 ^  、xor 只有两个对应位不同时才为1

左移

假设要将一个无符号整数 乘以2。可以简单地将所有位向左边移动一个位置(假设没有溢出)。

负数、1的补码、2的补码

在计算机中,有符号数据通常用它们的 2的补码 表示。1的补码 加1 得到它的2的补码。

那么如何求一个数的1的补数呢? x 的一个补是由 ~x 给出的。通过对一

以上是关于从C语言的角度重构数据结构系列(十三)-位运算的主要内容,如果未能解决你的问题,请参考以下文章

从原生 C++ 重构代码位的选项?

编程思想:巧用位运算重构代码

C语言求两个整型数据的“&”运算结果,打印输出运算结果的二进制位模式。

C语言-基本数据类型与位运算

C语言 位运算

有人知道C语言中&和^的使用方法吗?