结论:①应用于两个数据间值互换,②应用于奇偶校验。

异或:相同为0,不同为1。


 

一、可用于两个整数的值进行交换,不用借助第三个变量。

若a = 5(0101),b = 10(1010)经以下变换,可完成 值 的交换:
a=a^b; 0101 ^ 1010= 1111
b=b^a; 1010 ^ 1111 = 0101
a=a^b;  1111 ^ 0101= 1010
最后得:a = 10,b = 5。

二、可用于奇偶校验

  ^a:将数据a中的每一位按位逐一进行 异或,最后结果为1位宽(0或1)。

例如:a=4'b0101,则b=1^0^1^0=0,由此可以得到数据a中为1的位数个数是偶数。

三、应用举例——四位数据奇偶校验器

功能:用于检测四位宽数据中1的个数是奇数还是偶数。

Verilog Code:

1 module odd_even
2 (
3 input   wire  [3:0]  data,//4位宽数据输入
4 output  wire         flag //奇偶标志位输出
5 );
6 assign flag = ^data;//按位逐一异或
7 endmodule