(2) 實現兩個值的交換,而不必使用臨時變數。
例如交換兩個整數a=10100001,b=00000110的值,可通過下列語句實現:
a = a^b; //a=10100111
b = b^a; //b=10100001
a = a^b; //a=00000110
(3) 在組合語言中經常用於將變數置零:
xor a,a
1view codestatic inline int ipv6_addr_equal(const
struct in6_addr *a1, const
struct in6_addr *a2)
2
1view codestatic inline int ipv6_addr_equal(const
struct in6_addr *a1, const
struct in6_addr *a2)
2
5 應用通式:
對兩個表示式執行按位異或。
result = expression1 ^ expression2
引數result
任何變數。
expression1
任何表示式。
expression2
任何表示式。
說明^ 運算子檢視兩個表示式的二進位制表示法的值,並執行按位異或。該操作的結果如下所示:
0101 (expression1)1100 (expression2)----1001 (結果)當且僅當只有乙個表示式的某位上為 1 時,結果的該位才為 1。否則結果的該位為 0。
只能用於整數
下面這個程式用到了「按位異或」運算子:
1view codeclass
e 2
17 }
就是加密啊解密啊
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
1view codestatic inline int ipv6_addr_equal(const
struct in6_addr *a1, const
struct in6_addr *a2)
2
1view codestatic inline int ipv6_addr_equal(const
struct in6_addr *a1, const
struct in6_addr *a2)
2
5 應用通式:
對兩個表示式執行按位異或。
result = expression1 ^ expression2
引數result
任何變數。
expression1
任何表示式。
expression2
任何表示式。
說明^ 運算子檢視兩個表示式的二進位制表示法的值,並執行按位異或。該操作的結果如下所示:
0101 (expression1)1100 (expression2)----1001 (結果)當且僅當只有乙個表示式的某位上為 1 時,結果的該位才為 1。否則結果的該位為 0。
只能用於整數
下面這個程式用到了「按位異或」運算子:
1view codeclass
e 2
17 }
就是加密啊解密啊
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的規則...