什么生肖怕老婆| 血色病是什么病| ctc什么意思| 肾虚吃什么| 庚五行属什么| 为什么说金克木生财| 皮可以加什么偏旁| 梦见大便是什么预兆| 为什么不能空腹喝牛奶| belle什么意思| 膀胱钙化是什么意思| 什么是抗氧化| 香片属于什么茶| 血液是由什么组成的| 婴儿增强免疫力吃什么| 梦见扫地是什么预兆| 内裤上有黄色分泌物是什么原因| 欲望什么意思| 妊娠期是指什么时候| 倒班是什么意思| 头大是什么原因造成的| 韭菜补什么| 晚上六点半是什么时辰| 为什么下巴经常长痘痘| 干支是什么意思| names是什么意思| 吃避孕药有什么危害| 钻石是什么材质| 猫肉为什么不能吃| 9.25是什么星座| 复制是什么意思| 阴道瘙痒什么原因| 流产药叫什么名字| 名垂千古是什么意思| 酒糟鼻买什么药膏去红| 吃什么补维生素D效果最好| 肠炎吃什么药效果好| 乾隆的名字叫什么| 头痒用什么东西洗头最好| ms是什么单位| 什么叫肺结节| 牙疼吃什么止疼药| 本命年红内衣什么时候穿| 高圆圆老公叫什么名字| 吃什么东西补血最快| 嬴稷和嬴政是什么关系| white是什么意思颜色| 巨蟹座是什么象| 重色轻友什么意思| 低置胎盘有什么危险| 活泼开朗是什么意思| 海里有什么鱼| 早上空腹喝淡盐水有什么好处| 冰释前嫌什么意思| 头皮问题挂什么科| 点映什么意思| 升阳举陷是什么意思| 梦见晒被子是什么意思| 眼睛红用什么眼药水| squirrel是什么意思| 丢包是什么意思| 空调什么品牌好| 子宫位于腹部什么位置| 为什么会长虱子| 脸上白了一小块是什么原因| 真狗是什么意思| 用什么方法可以戒酒| 舌苔白厚腻吃什么药| 新陈代谢是什么意思| 猴与什么属相相配最好| 黄芪的功效是什么| 住院需要带什么生活用品| 什么是假声| 绿壳鸡蛋是什么鸡生的| 毛拉是什么意思| 生产周期是什么意思| 肚子胀气老放屁是什么原因| 柏字五行属什么| 吃金针菇有什么好处| 肚子疼是什么病| 什么的宝石| 官员出狱后靠什么生活| 猕猴桃不能和什么一起吃| 水痘可以吃什么水果| 指甲紫色是什么病的征兆| 高烧不退是什么原因| 今天属什么生肖日历| 大便黄绿色是什么原因| 攒局什么意思| 小便带血是什么原因| 燥是什么意思| swisse是什么药| 牛奶有什么营养| 癫痫是什么意思| 手上起水泡是什么原因| 符号叫什么| 浙江有什么旅游景点| 四川大学校长什么级别| 布鲁斯是什么意思| 脖子痒是什么原因| 帕金森挂什么科| 嘴巴里苦是什么原因| 白虎女是什么意思| 心脏积液吃什么药最好| 婴儿头发长得慢是什么原因| 双子座前面是什么星座| 根是什么意思| 灰指甲不治疗有什么后果| 便秘去药店买什么药吃| 甲状腺不能吃什么| 汉菜不能和什么一起吃| 梦见拉屎是什么意思| 尿酸偏高有什么危害| 男人太瘦吃什么可以长胖| 胰腺炎吃什么药好| 乙型肝炎病毒表面抗体阳性是什么意思| 自闭是什么意思| 辣的部首是什么| gn是什么单位| 吃高血压药有什么副作用| 台风什么时候到上海| 梦见死人复活是什么意思| 耳朵痛用什么药| 查电话号码打什么电话| 红肉是指什么肉| 清奇是什么意思| 肠梗阻什么症状| 用一什么就什么造句| 头发有点黄是什么原因| lb是什么| 洗耳朵用什么药水| 冬占生男是什么意思| 发小是什么| 手脱皮什么原因| 肌酐高有什么症状| 打醮是什么意思| 白带清洁度lll度是什么意思| ur是什么缩写| 大小周休息是什么意思| 檄文是什么意思| 1108是什么星座| 孕妇建档是什么意思| 农历五月十八是什么日子| 可乐煮姜有什么作用| 副县长什么级别| 抬头纹开了是什么意思| 场所是什么意思| 肋骨痛挂什么科| 血小板低是什么病| 五行木是什么颜色| 姜粉什么时候喝最好| 朱的部首是什么| 神经性皮炎用什么药| 血栓吃什么药可以疏通血管| 喝酒有什么危害| 胃胀不消化吃什么药| 梦到女孩子有什么预兆| 咳嗽吃什么| 单脐动脉对胎儿有什么影响| 膝盖疼痛是什么原因| 农村入党需要什么条件| 五海瘿瘤丸主要治什么病| 楔形是什么形状| 佛性是什么意思| 婴儿补铁吃什么铁剂| 三什么什么什么成语| 什么而不| jerry英文名什么意思| 井代表什么生肖| 雍正叫什么| 嗓子沙哑吃什么药| 什么炒蛋好吃| 查肾功能需要做什么检查| 男人更年期在什么年龄| 浅尝辄止什么意思| 吃什么对肺有好处| 堃什么意思| 尿频尿急是什么原因| 西地那非是什么| 性侵是什么意思| 肋骨骨折什么症状| 什么是夹角| 心腹是什么意思| crispi是什么牌子| pin是什么意思啊| 用什么方法止咳| 血糖高什么原因| 心慌是什么感觉| 拂尘是什么意思| 怀孕做糖耐是检查什么| 肝脏挂什么科| 吃什么水果最好| 虚不受补是什么意思| 心肺气虚吃什么中成药| 吃什么药可以流产不用去医院| 吧唧嘴什么意思| 大姨妈一直不干净是什么原因| 指甲白色是什么原因| 三无产品是指什么| 什么原因得疱疹| 黄什么鱼| 怀孕皮肤变差什么原因| 八段锦什么时间练最好| 天生一对成伴侣是什么生肖| 头发干枯毛躁是什么原因| 嘌呤高会引起什么症状| 伤口发痒是什么原因| 什么时候有流星| 感化是什么意思| 什么是同人文| 梦见穿袜子是什么意思| 马和驴为什么能杂交| 胖脸适合什么发型| 为什么会突然流鼻血| 乙肝两对半挂什么科| 盆腔积液用什么药| 愿字五行属什么| 下呼吸道是指什么部位| 个性是什么意思| 什么的芦花| 雾化后为什么要漱口| 什么的腊梅| 为什么得甲亢| 梦见穿新衣服是什么意思| 娇妻是什么意思| 孩子鼻子流鼻血是什么原因| lv中文名叫什么| 一个黑一个俊的右边念什么| 正月十五是什么节| 九五年属什么生肖| 薄荷有什么功效| 7月初7是什么节日| 红虫是什么的幼虫| 流觞是什么意思| 炉甘石是什么东西| 子宫内膜14mm说明什么| 心脏早搏是什么原因造成的| 梦见插秧是什么意思| 胃癌是什么原因引起的| 气血不足吃什么补最快| 行房出血是什么原因| 一什么手套| 宝宝手心热是什么原因| 例假淋漓不尽是什么原因造成的| 火星上有什么| 梦见掉头发是什么意思| molly英文名什么意思| 为什么乳头会变硬| 木字多一撇是什么字| 117是什么电话| 内热是什么原因引起的怎么调理| 1109是什么星座| 最大的沙漠是什么| 乳腺癌吃什么好| 射手后面的星座是什么| 水床是什么| 喝蒲公英茶有什么作用| 苦瓜煮水喝有什么功效| 拉屎为什么是黑色的| ngu是什么意思| 补钙吃什么维生素| 瘦人吃什么长胖| 什么叫阴虚| 频繁打喷嚏是什么原因| 百度Jump to content

头发掉什么原因

From Wikipedia, the free encyclopedia
(Redirected from Bitwise AND)
百度 当然更多的网友只能说:别人家的老板,意思自然是自己遇不到这样的好老板了。

In computer programming, a bitwise operation operates on a bit string, a bit array or a binary numeral (considered as a bit string) at the level of its individual bits. It is a fast and simple action, basic to the higher-level arithmetic operations and directly supported by the processor. Most bitwise operations are presented as two-operand instructions where the result replaces one of the input operands.

On simple low-cost processors, typically, bitwise operations are substantially faster than division, several times faster than multiplication, and sometimes significantly faster than addition. While modern processors usually perform addition and multiplication just as fast as bitwise operations due to their longer instruction pipelines and other architectural design choices, bitwise operations do commonly use less power because of the reduced use of resources.[1]

Bitwise operators

[edit]

In the explanations below, any indication of a bit's position is counted from the right (least significant) side, advancing left. For example, the binary value 0001 (decimal 1) has zeroes at every position but the first (i.e., the rightmost) one.

NOT

[edit]

The bitwise NOT, or bitwise complement, is a unary operation that performs logical negation on each bit, forming the ones' complement of the given binary value. Bits that are 0 become 1, and those that are 1 become 0. For example:

NOT 0111  (decimal 7)
  = 1000  (decimal 8)
NOT 10101011  (decimal 171)
  = 01010100  (decimal 84)

The result is equal to the two's complement of the value minus one. If two's complement arithmetic is used, then NOT x = -x ? 1.

For unsigned integers, the bitwise complement of a number is the "mirror reflection" of the number across the half-way point of the unsigned integer's range. For example, for 8-bit unsigned integers, NOT x = 255 - x, which can be visualized on a graph as a downward line that effectively "flips" an increasing range from 0 to 255, to a decreasing range from 255 to 0. A simple but illustrative example use is to invert a grayscale image where each pixel is stored as an unsigned integer.

AND

[edit]
Bitwise AND of 4-bit integers

A bitwise AND is a binary operation that takes two equal-length binary representations and performs the logical AND operation on each pair of the corresponding bits. Thus, if both bits in the compared position are 1, the bit in the resulting binary representation is 1 (1 × 1 = 1); otherwise, the result is 0 (1 × 0 = 0 and 0 × 0 = 0). For example:

    0101 (decimal 5)
AND 0011 (decimal 3)
  = 0001 (decimal 1)

The operation may be used to determine whether a particular bit is set (1) or cleared (0). For example, given a bit pattern 0011 (decimal 3), to determine whether the second bit is set we use a bitwise AND with a bit pattern containing 1 only in the second bit:

    0011 (decimal 3)
AND 0010 (decimal 2)
  = 0010 (decimal 2)

Because the result 0010 is non-zero, we know the second bit in the original pattern was set. This is often called bit masking. (By analogy, the use of masking tape covers, or masks, portions that should not be altered or portions that are not of interest. In this case, the 0 values mask the bits that are not of interest.)

The bitwise AND may be used to clear selected bits (or flags) of a register in which each bit represents an individual Boolean state. This technique is an efficient way to store a number of Boolean values using as little memory as possible.

For example, 0110 (decimal 6) can be considered a set of four flags numbered from right to left, where the first and fourth flags are clear (0), and the second and third flags are set (1). The third flag may be cleared by using a bitwise AND with the pattern that has a zero only in the third bit:

    0110 (decimal 6)
AND 1011 (decimal 11)
  = 0010 (decimal 2)

Because of this property, it becomes easy to check the parity of a binary number by checking the value of the lowest valued bit. Using the example above:

    0110 (decimal 6)
AND 0001 (decimal 1)
  = 0000 (decimal 0)

Because 6 AND 1 is zero, 6 is divisible by two and therefore even.

OR

[edit]
Bitwise OR of 4-bit integers

A bitwise OR is a binary operation that takes two bit patterns of equal length and performs the logical inclusive OR operation on each pair of corresponding bits. The result in each position is 0 if both bits are 0, while otherwise the result is 1. For example:

   0101 (decimal 5)
OR 0011 (decimal 3)
 = 0111 (decimal 7)

The bitwise OR may be used to set to 1 the selected bits of the register described above. For example, the fourth bit of 0010 (decimal 2) may be set by performing a bitwise OR with the pattern with only the fourth bit set:

   0010 (decimal 2)
OR 1000 (decimal 8)
 = 1010 (decimal 10)

XOR

[edit]
Bitwise XOR of 4-bit integers

A bitwise XOR is a binary operation that takes two bit patterns of equal length and performs the logical exclusive OR operation on each pair of corresponding bits. The result in each position is 1 if only one of the bits is 1, but will be 0 if both are 0 or both are 1. In this we perform the comparison of two bits, being 1 if the two bits are different, and 0 if they are the same. For example:

    0101 (decimal 5)
XOR 0011 (decimal 3)
  = 0110 (decimal 6)

The bitwise XOR may be used to invert selected bits in a register (also called toggle or flip). Any bit may be toggled by XORing it with 1. For example, given the bit pattern 0010 (decimal 2) the second and fourth bits may be toggled by a bitwise XOR with a bit pattern containing 1 in the second and fourth positions:

    0010 (decimal 2)
XOR 1010 (decimal 10)
  = 1000 (decimal 8)

This technique may be used to manipulate bit patterns representing sets of Boolean states.

Assembly language programmers and optimizing compilers sometimes use XOR as a short-cut to setting the value of a register to zero. Performing XOR on a value against itself always yields zero, and on many architectures this operation requires fewer clock cycles and less memory than loading a zero value and saving it to the register.

If the set of bit strings of fixed length n (i.e. machine words) is thought of as an n-dimensional vector space over the field , then vector addition corresponds to the bitwise XOR.

Mathematical equivalents

[edit]

Assuming ??, for the non-negative integers, the bitwise operations can be written as follows:

Truth table for all binary logical operators

[edit]

There are 16 possible truth functions of two binary variables; this defines a truth table.

Here is the bitwise equivalent operations of two bits P and Q:

p q F0 NOR1 Xq2 ?p3 ?4 ?q5 XOR6 NAND7 AND8 XNOR9 q10 If/then11 p12 Then/if13 OR14 T15
1 1 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1
1 0 0 0 0 0 1 1 1 1 0 0 0 0 1 1 1 1
0 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1
0 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1
Bitwise
equivalents
0 NOT
(p OR q)
(NOT p)
AND q
NOT
p
p AND
(NOT q)
NOT
q
p XOR q NOT
(p AND q)
p AND q NOT
(p XOR q)
q (NOT p)
OR q
p p OR
(NOT q)
p OR q 1

Bit shifts

[edit]

The bit shifts are sometimes considered bitwise operations, because they treat a value as a series of bits rather than as a numerical quantity. In these operations, the digits are moved, or shifted, to the left or right. Registers in a computer processor have a fixed width, so some bits will be "shifted out" of the register at one end, while the same number of bits are "shifted in" from the other end; the differences between bit shift operators lie in how they determine the values of the shifted-in bits.

Bit addressing

[edit]

If the width of the register (frequently 32 or even 64) is larger than the number of bits (usually 8) of the smallest addressable unit, frequently called byte, the shift operations induce an addressing scheme from the bytes to the bits. Thereby the orientations "left" and "right" are taken from the standard writing of numbers in a place-value notation, such that a left shift increases and a right shift decreases the value of the number ― if the left digits are read first, this makes up a big-endian orientation. Disregarding the boundary effects at both ends of the register, arithmetic and logical shift operations behave the same, and a shift by 8 bit positions transports the bit pattern by 1 byte position in the following way:

Little-endian ordering: a left shift by 8 positions increases the byte address by 1,
a right shift by 8 positions decreases the byte address by 1.
Big-endian ordering: a left shift by 8 positions decreases the byte address by 1,
a right shift by 8 positions increases the byte address by 1.

Arithmetic shift

[edit]
Left arithmetic shift
Right arithmetic shift

In an arithmetic shift (sticky shift), the bits that are shifted out of either end are discarded. In a left arithmetic shift, zeros are shifted in on the right; in a right arithmetic shift, the sign bit (the MSB in two's complement) is shifted in on the left, thus preserving the sign of the operand.

This example uses an 8-bit register, interpreted as two's complement:

   00010111 (decimal +23) LEFT-SHIFT
=  00101110 (decimal +46)
   10010111 (decimal ?105) RIGHT-SHIFT
=  11001011 (decimal ?53)

In the first case, the leftmost digit was shifted past the end of the register, and a new 0 was shifted into the rightmost position. In the second case, the rightmost 1 was shifted out (perhaps into the carry flag), and a new 1 was copied into the leftmost position, preserving the sign of the number. Multiple shifts are sometimes shortened to a single shift by some number of digits. For example:

   00010111 (decimal +23) LEFT-SHIFT-BY-TWO
=  01011100 (decimal +92)

A left arithmetic shift by n is equivalent to multiplying by 2n (provided the value does not overflow), while a right arithmetic shift by n of a two's complement value is equivalent to taking the floor of division by 2n. If the binary number is treated as ones' complement, then the same right-shift operation results in division by 2n and rounding toward zero.

Logical shift

[edit]
Left logical shift
Right logical shift

In a logical shift (zero fill shift), zeros are shifted in to replace the discarded bits. Therefore, the logical and arithmetic left-shifts are exactly the same.

However, as the logical right-shift inserts value 0 bits into the most significant bit, instead of copying the sign bit, it is ideal for unsigned binary numbers, while the arithmetic right-shift is ideal for signed two's complement binary numbers.

Circular shift

[edit]

Another form of shift is the circular shift, bitwise rotation or bit rotation.

Rotate

[edit]
Left circular shift or rotate
Right circular shift or rotate

In this operation, sometimes called rotate no carry, the bits are "rotated" as if the left and right ends of the register were joined. The value that is shifted into the right during a left-shift is whatever value was shifted out on the left, and vice versa for a right-shift operation. This is useful if it is necessary to retain all the existing bits, and is frequently used in digital cryptography.[clarification needed]

Rotate through carry

[edit]
Left rotate through carry
Right rotate through carry

Rotate through carry is a variant of the rotate operation, where the bit that is shifted in (on either end) is the old value of the carry flag, and the bit that is shifted out (on the other end) becomes the new value of the carry flag.

A single rotate through carry can simulate a logical or arithmetic shift of one position by setting up the carry flag beforehand. For example, if the carry flag contains 0, then x RIGHT-ROTATE-THROUGH-CARRY-BY-ONE is a logical right-shift, and if the carry flag contains a copy of the sign bit, then x RIGHT-ROTATE-THROUGH-CARRY-BY-ONE is an arithmetic right-shift. For this reason, some microcontrollers such as low end PICs just have rotate and rotate through carry, and don't bother with arithmetic or logical shift instructions.

Rotate through carry is especially useful when performing shifts on numbers larger than the processor's native word size, because if a large number is stored in two registers, the bit that is shifted off one end of the first register must come in at the other end of the second. With rotate-through-carry, that bit is "saved" in the carry flag during the first shift, ready to shift in during the second shift without any extra preparation.

In high-level languages

[edit]

In C family of languages

[edit]

In C and C++ languages, the logical shift operators are "<<" for left shift and ">>" for right shift. The number of places to shift is given as the second argument to the operator. For example,

x = y << 2;

assigns x the result of shifting y to the left by two bits, which is equivalent to a multiplication by four.

Shifts can result in implementation-defined behavior or undefined behavior, so care must be taken when using them. The result of shifting by a bit count greater than or equal to the word's size is undefined behavior in C and C++.[2][3] Right-shifting a negative value is implementation-defined and not recommended by good coding practice;[4] the result of left-shifting a signed value is undefined if the result cannot be represented in the result type.[2]

In C#, the right-shift is an arithmetic shift when the first operand is an int or long. If the first operand is of type uint or ulong, the right-shift is a logical shift.[5]

Circular shifts
[edit]

The C-family of languages lack a rotate operator (although C++20 provides std::rotl and std::rotr), but one can be synthesized from the shift operators. Care must be taken to ensure the statement is well formed to avoid undefined behavior and timing attacks in software with security requirements.[6] For example, a naive implementation that left-rotates a 32-bit unsigned value x by n positions is simply

uint32_t x = ..., n = ...;
uint32_t y = (x << n) | (x >> (32 - n));

However, a shift by 0 bits results in undefined behavior in the right-hand expression (x >> (32 - n)) because 32 - 0 is 32, and 32 is outside the range 0–31 inclusive. A second try might result in

uint32_t x = ..., n = ...;
uint32_t y = n ? (x << n) | (x >> (32 - n)) : x;

where the shift amount is tested to ensure that it does not introduce undefined behavior. However, the branch adds an additional code path and presents an opportunity for timing analysis and attack, which is often not acceptable in high-integrity software.[6] In addition, the code compiles to multiple machine instructions, which is often less efficient than the processor's native instruction.

To avoid the undefined behavior and branches under GCC and Clang, the following is recommended. The pattern is recognized by many compilers, and the compiler will emit a single rotate instruction:[7][8][9]

uint32_t x = ..., n = ...;
uint32_t y = (x << n) | (x >> (-n & 31));

There are also compiler-specific intrinsics implementing circular shifts, like _rotl8, _rotl16, _rotr8, _rotr16 in Microsoft Visual C++. Clang provides some rotate intrinsics for Microsoft compatibility that suffers the problems above.[9] GCC does not offer rotate intrinsics. Intel also provides x86 intrinsics.

Java

[edit]

In Java, all integer types are signed, so the "<<" and ">>" operators perform arithmetic shifts. Java adds the operator ">>>" to perform logical right shifts, but since the logical and arithmetic left-shift operations are identical for signed integer, there is no "<<<" operator in Java.

More details of Java shift operators:[10]

  • The operators << (left shift), >> (signed right shift), and >>> (unsigned right shift) are called the shift operators.
  • The type of the shift expression is the promoted type of the left-hand operand. For example, aByte >>> 2 is equivalent to ((int) aByte) >>> 2.
  • If the promoted type of the left-hand operand is int, only the five lowest-order bits of the right-hand operand are used as the shift distance. It is as if the right-hand operand were subjected to a bitwise logical AND operator & with the mask value 0x1f (0b11111).[11] The shift distance actually used is therefore always in the range 0 to 31, inclusive.
  • If the promoted type of the left-hand operand is long, then only the six lowest-order bits of the right-hand operand are used as the shift distance. It is as if the right-hand operand were subjected to a bitwise logical AND operator & with the mask value 0x3f (0b111111).[11] The shift distance actually used is therefore always in the range 0 to 63, inclusive.
  • The value of n >>> s is n right-shifted s bit positions with zero-extension.
  • In bit and shift operations, the type byte is implicitly converted to int. If the byte value is negative, the highest bit is one, then ones are used to fill up the extra bytes in the int. So byte b1 = -5; int i = b1 | 0x0200; will result in i == -5.

JavaScript

[edit]

JavaScript uses bitwise operations to evaluate each of two or more units place to 1 or 0.[12]

Pascal

[edit]

In Pascal, as well as in all its dialects (such as Object Pascal and Standard Pascal), the logical left and right shift operators are "shl" and "shr", respectively. Even for signed integers, shr behaves like a logical shift, and does not copy the sign bit. The number of places to shift is given as the second argument. For example, the following assigns x the result of shifting y to the left by two bits:

x := y shl 2;

Other

[edit]

Applications

[edit]

Bitwise operations are necessary particularly in lower-level programming such as device drivers, low-level graphics, communications protocol packet assembly, and decoding.

Although machines often have efficient built-in instructions for performing arithmetic and logical operations, all these operations can be performed by combining the bitwise operators and zero-testing in various ways.[13] For example, here is a pseudocode implementation of ancient Egyptian multiplication showing how to multiply two arbitrary integers a and b (a greater than b) using only bitshifts and addition:

c  0
while b  0
    if (b and 1)  0
        c  c + a
    left shift a by 1
    right shift b by 1
return c

Another example is a pseudocode implementation of addition, showing how to calculate a sum of two integers a and b using bitwise operators and zero-testing:

while a  0
    c  b and a
    b  b xor a
    left shift c by 1
    a  c
return b

Boolean algebra

[edit]

Sometimes it is useful to simplify complex expressions made up of bitwise operations, for example when writing compilers. The goal of a compiler is to translate a high-level programming language into the most efficient machine code possible. Boolean algebra is used to simplify complex bitwise expressions.

AND

[edit]
  • x & y = y & x
  • x & (y & z) = (x & y) & z
  • x & 0xFFFF = x[14]
  • x & 0 = 0
  • x & x = x

OR

[edit]
  • x | y = y | x
  • x | (y | z) = (x | y) | z
  • x | 0 = x
  • x | 0xFFFF = 0xFFFF
  • x | x = x

NOT

[edit]
  • ~(~x) = x

XOR

[edit]
  • x ^ y = y ^ x
  • x ^ (y ^ z) = (x ^ y) ^ z
  • x ^ 0 = x
  • x ^ y ^ y = x
  • x ^ x = 0
  • x ^ 0xFFFF = ~x

Additionally, XOR can be composed using the 3 basic operations (AND, OR, NOT)

  • a ^ b = (a | b) & (~a | ~b)
  • a ^ b = (a & ~b) | (~a & b)

Others

[edit]
  • x | (x & y) = x
  • x & (x | y) = x
  • ~(x | y) = ~x & ~y
  • ~(x & y) = ~x | ~y
  • x | (y & z) = (x | y) & (x | z)
  • x & (y | z) = (x & y) | (x & z)
  • x & (y ^ z) = (x & y) ^ (x & z)
  • x + y = (x ^ y) + ((x & y) << 1)
  • x - y = ~(~x + y)

Inverses and solving equations

[edit]

It can be hard to solve for variables in Boolean algebra, because unlike regular algebra, several operations do not have inverses. Operations without inverses lose some of the original data bits when they are performed, and it is not possible to recover this missing information.

  • Has inverse
    • NOT
    • XOR
    • Rotate left
    • Rotate right
  • No inverse
    • AND
    • OR
    • Shift left
    • Shift right

Order of operations

[edit]

Operations at the top of this list are executed first. See the main article for a more complete list.

See also

[edit]

References

[edit]
  1. ^ "CMicrotek Low-power Design Blog". CMicrotek. Retrieved 2025-08-06.
  2. ^ a b JTC1/SC22/WG14 N843 "C programming language", section 6.5.7
  3. ^ "Arithmetic operators - cppreference.com". en.cppreference.com. Retrieved 2025-08-06.
  4. ^ "INT13-C. Use bitwise operators only on unsigned operands". CERT: Secure Coding Standards. Software Engineering Institute, Carnegie Mellon University. Retrieved 2025-08-06.
  5. ^ "Operator (C# Reference)". Microsoft. Retrieved 2025-08-06.
  6. ^ a b "Near constant time rotate that does not violate the standards?". Stack Exchange Network. Retrieved 2025-08-06.
  7. ^ "Poor optimization of portable rotate idiom". GNU GCC Project. Retrieved 2025-08-06.
  8. ^ "Circular rotate that does not violate C/C++ standard?". Intel Developer Forums. Retrieved 2025-08-06.
  9. ^ a b "Constant not propagated into inline assembly, results in "constraint 'I' expects an integer constant expression"". LLVM Project. Retrieved 2025-08-06.
  10. ^ The Java Language Specification, section 15.19. Shift Operators
  11. ^ a b "Chapter 15. Expressions". oracle.com.
  12. ^ "JavaScript Bitwise". W3Schools.com.
  13. ^ "Synthesizing arithmetic operations using bit-shifting tricks". Bisqwit.iki.fi. 2025-08-06. Retrieved 2025-08-06.
  14. ^ Throughout this article, 0xFFFF means that all the bits in your data type need to be set to 1. The exact number of bits depends on the width of the data type.
  15. ^ - is negation here, not subtraction
  16. ^ - is subtraction here, not negation
[edit]
铁树开花是什么生肖 12月份是什么星座的 女生为什么会喷水 淮山是什么 厦门为什么叫厦门
高考什么时候恢复的 旦上面加一横是什么字 高校新生是什么意思 一什么月牙 见字如面什么意思
大姨妈发黑是什么原因 93年什么命 扁桃体发炎吃什么中成药 冰心的原名是什么 月经期间喝红糖水有什么好处
苦荞是什么植物 秋葵补什么 如履薄冰什么意思 羊水是什么 鼻梁痛什么原因引起的
姨妈不正常是什么原因hcv9jop4ns6r.cn 补办医保卡需要什么资料hcv8jop4ns8r.cn 怀孕肚子疼是什么原因hcv7jop7ns2r.cn 紫癜是什么病 严重吗hcv7jop9ns2r.cn 代偿是什么意思hcv8jop8ns2r.cn
为什么正骨后几天越来越疼hcv8jop5ns4r.cn 检查胃应该挂什么科hcv9jop5ns8r.cn ptc是什么wuhaiwuya.com 5.21什么星座hcv9jop8ns0r.cn 富屋贫人是什么意思hcv8jop5ns1r.cn
下眼睑跳动是什么原因hcv9jop5ns2r.cn 细胞学说揭示了什么chuanglingweilai.com 一九七七年属什么生肖hcv9jop0ns6r.cn 中指和无名指一样长代表什么hcv8jop1ns2r.cn 慢性胃炎吃什么好hcv9jop1ns4r.cn
96120是什么电话xinjiangjialails.com 中途疲软吃什么药hcv9jop1ns3r.cn 中国什么姓氏人口最多sscsqa.com 高丽棒子是什么意思hcv7jop6ns0r.cn 普洱茶属于什么茶类hcv8jop0ns4r.cn
百度