按位異或運算子

2022-03-21 10:12:48 字數 2031 閱讀 9760

(2) 實現兩個值的交換,而不必使用臨時變數。

例如交換兩個整數a=10100001,b=00000110的值,可通過下列語句實現:

a = a^b;   //a=10100111

b = b^a;   //b=10100001

a = a^b;   //a=00000110

(3) 在組合語言中經常用於將變數置零:

xor   a,a

1

static inline int ipv6_addr_equal(const

struct in6_addr *a1, const

struct in6_addr *a2)

2

view code

1

static inline int ipv6_addr_equal(const

struct in6_addr *a1, const

struct in6_addr *a2)

2

view code

5  應用通式:

對兩個表示式執行按位異或。

result = expression1 ^ expression2

引數result

任何變數。

expression1

任何表示式。

expression2

任何表示式。

說明^ 運算子檢視兩個表示式的二進位制表示法的值,並執行按位異或。該操作的結果如下所示:

0101     (expression1)1100     (expression2)----1001     (結果)當且僅當只有乙個表示式的某位上為 1 時,結果的該位才為 1。否則結果的該位為 0。

只能用於整數

下面這個程式用到了「按位異或」運算子:

1

class

e 2

17 }

view code

就是加密啊解密啊

char型別,也就是字元型別實際上就是整形,就是數字.

(2) 實現兩個值的交換,而不必使用臨時變數。

例如交換兩個整數a=10100001,b=00000110的值,可通過下列語句實現:

a = a^b;   //a=10100111

b = b^a;   //b=10100001

a = a^b;   //a=00000110

(3) 在組合語言中經常用於將變數置零:

xor   a,a

1

static inline int ipv6_addr_equal(const

struct in6_addr *a1, const

struct in6_addr *a2)

2

view code

1

static inline int ipv6_addr_equal(const

struct in6_addr *a1, const

struct in6_addr *a2)

2

view code

5  應用通式:

對兩個表示式執行按位異或。

result = expression1 ^ expression2

引數result

任何變數。

expression1

任何表示式。

expression2

任何表示式。

說明^ 運算子檢視兩個表示式的二進位制表示法的值,並執行按位異或。該操作的結果如下所示:

0101     (expression1)1100     (expression2)----1001     (結果)當且僅當只有乙個表示式的某位上為 1 時,結果的該位才為 1。否則結果的該位為 0。

只能用於整數

下面這個程式用到了「按位異或」運算子:

1

class

e 2

17 }

view code

就是加密啊解密啊

char型別,也就是字元型別實際上就是整形,就是數字.

按位異或運算子

參與運算的兩個值,如果兩個相應位相同,則結果為0,否則為1。即 0 0 0,1 0 1,0 1 1,1 1 0 例如 10100001 00010001 10110000 0 0 0,0 1 1 0異或任何數 任何數 1 0 1,1 1 0 1異或任何數 任何數取反 任何數異或自己 把自己置0 1 ...

深度理解按位異或運算子

參與運算的兩個值,如果兩個相應位相同,則結果為0,否則為1。即 0 0 0,1 0 1,0 1 1,1 1 0 例如 10100001 00010001 10110000 0 0 0,0 1 1 0異或任何數 任何數 1 0 1,1 1 0 1異或任何數 任何數取反 任何數異或自己 把自己置0 1 ...

運算子的計算(按位與 按位或 異或 取反)

運算規則 依次比較兩個二進位制數的每一位,按照有0則0,否則為1的規則,依次計算出乙個新的二進位制數 即 0 0 0 0 1 0,1 0 0,1 1 1 例 39 21 0010 0111 0001 0101 0000 0101 運算規則 依次比較兩個二進位制數的每一位,按照有1則1,否則為0的規則...