标签:
二元 ^ 运算符是为整型和 bool 类型预定义的。对于整型,^ 将计算操作数的按位“异或”。对于 bool 操作数,^ 将计算操作数的逻辑“异或”;也就是说,当且仅当只有一个操作数为 true 时,结果才为 true。
如两个二进制数的相应位都为1 或者二进制数的相应位都为0,则返回0;如果两个二进制数相应位一个为0,另一个为1则返回1;
加密:将23进行异或运算加密,key为15
解密:将加密结果:24进行异或运算解密,key=15
注释1:23转2进制算法流程
注释2:将10111和1111进行异或运算规则比较:
注释3:11000转为10进制数:1*2^4+1*2^3+0*2^2+0*2^1+0*2^0=16+8+0+0+0=24
四:编写加密小工具:
程序的主要代码如下:
/// <summary> ///加密 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void button1_Click(object sender, EventArgs e) { int num, key; if (int.TryParse(this.textBox1.Text, out key) && int.TryParse(this.textBox2.Text, out num)) { this.label4.Text = (num ^ key).ToString(); } else { MessageBox.Show("请输入数值","出现错误"); } }
/// <summary> /// 解密 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void button2_Click(object sender, EventArgs e) { int key, encrypt; if (int.TryParse(this.textBox1.Text, out key) && int.TryParse(this.label4.Text,out encrypt)) { this.label5.Text = (key ^ encrypt).ToString(); } else { MessageBox.Show("请输入数值", "出现错误"); } }
标签:
原文地址:http://www.cnblogs.com/heyangyi/p/5959772.html