经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C# » 查看文章
C# 位运算详解
来源:cnblogs  作者:薛定谔家的猫  时间:2018/12/7 9:38:25  对本文有异议
运算符描述
&(位与) 当两个二进制操作位都为1时,结果就为1
|(位或) 当两个二进制操作位有1个为1时,结果就为1
^(位异或) 当两个二进制操作位只有1个为1时,结果为1
~(位非) 操作位的每个位都取反(就是0变成1,1变成0)
<<(左移) 二进制左移运算符。左操作数的值向左移动右操作数指定的位数。
>>(右移) 二进制右移运算符。左操作数的值向右移动右操作数指定的位数。

pq实例图

pqp & qp | qp ^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

如下 :

int x=12,y=10;

int a;

a=x&y; //a=8

下面是计算试子的和加减法一样

二进制的个位,十位,百位,千位,分别对应的是1,2,4,8 二进制每多一位只需要乘2 那个个位置有1 就加上该位置的十进制数 。

上面说&运算时,当两个二进制操作位都为1时,结果就为1

看个位 0&0 =0  十位 0&1=0   百位 1&0=0 千位1&1=1 

换下来就是 1000(二进制) =8(十进制) 12&10=8

12|10,12^10 可以试着就算这个值

位非怎么运算呢?

~12  直接位数取反 0变1,1变0 二进制左端1是位负数  在取反上-1

~12=-13; 

要获取他12的相反数 二进制表示 也是 取反 但是在结果上加1

 

左/右移  左移对移玩的位置补0 14<<3  二进制就是 1110>>1110 000 

就是 14X2X2X2=112  14<<3=112

右移 切记负数右移是错误的 因为一个负数无论如何除2都不会乘位一个正数  14>>3=1

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号