码迷,mamicode.com
首页 > 其他好文 > 详细

xor异或逻辑运算

时间:2015-12-04 18:06:39      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:

简略记忆:同0异1

1.由于0^0=0 0^1=1 所以,0^任何数 = 任何数
2.由于1^0=1 1^1 =0所以,1^任何数 = 任何数取反
3.任何数^任何数 = 0;
4.用于将特定的位反转,如对10100001的第2位和第3位翻转,可以将数与00000110进行按位异或运算。原因见(2)
5.通过按位异或运算,可以实现两个值的交换,而不必使用临时变量。
例如 a= 10100001 
b= 00000111
a=a^b; //a=10100110
  //此步操作是将a b原值的相同位记录为0,不同位记录为1.
  //并保存在a中,b值此步并没有发生变化
  //由于1^任何数 = 任何数取反 0^任何数 = 任何数
b=b^a; //b=10100001
  //a中用1表示原值中对应位不同的部分
  //做异或操作是将b中与(原a)中相同的部分保留,与(原a)中不同的部分取反
  //即将b编程原来的a
a=a^b //a=00000111
  //由于此时的a表示异同,b表示原来的a
  //同理第二部步可获得原b值,赋给a即可实现转换
6.异或运算的特点:a两次异或同一个数b(a=a^b^b)仍然为原值a。//参考(5)即可知。
7.异或是可交换的:a^b = b^a

xor异或逻辑运算

标签:

原文地址:http://www.cnblogs.com/thewaytomakemiracle/p/5019678.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!