逻辑运算和位运算

Java中负数的运算都是以补码的形式来进行的而且一个运算如果结果是负数,要从补码转换成它的源码得到运算结果

正数的源码、反码、补码是一样的

负数的反码是源码符号位不变,其他位取反,补码是反码加1

~取反操作:将所有位数全部0变1,1变0,不过如果正数取反得到的是负数,那么负数要从补码转回源码才可以,比如2的源码是00000000000000000……0010,取反之后是111111111111111……111101,这样得到的是负数,所以要从补码转回源码,先转成反码,是补码减1,得到的是11111111111…… 1111100,再转回源码,是符号位不变,其他位取反,得到的是10000000000000000……00000011,得到的是-3,所以~2=-3.

负数取反:

~(-5):1000000000000000  …… 00000101

反:  111111111111111111……111111010

补:  111111111111111111 ……11111011、

取反:0000000000000000000000000000100

得4

&位与:如果两个数字对应位数都为1,则结果为1,如果有至少一个为0,那么就为0.这个道理和逻辑与差不多。2&(-5),操作之前,由于-5是负数,要转换成补码再进行操作。

2:                 00000000000000000000000……00010

-5源码:            10000000000000000000000……00101

-5反码              11111111111111111111111……11010

是源码符号不变其他取反

-5补码是反码加1     11111111111111111111111……11011

和2与:           00000000000000000000000……00010

结果是               00000000000000000000000……00010

所以结果是2

“|”位或:2|3  :

00000000000000000000000000……000010

00000000000000000000000000……000011

结果是3.

2|(-3):         0000000000000000000000000000…… 00010

1000000000000000000000000000…… 00001(源 -1)

1111111111111111111111111111…… 11110(反)

1111111111111111111111111111…… 11111(与)

1111111111111111111111111111…… 11101(补)

1111111111111111111111111111…… 11100反

(从下到上)              1000000000000000000000000000…… 00011源

算术右移:>> 低位溢出,符号位不变,并用符号位补溢出的高位

算术左移:<<符号位不变低位补0

逻辑右移:低位溢出高位补0.和算术溢出的区别就在于如果逻辑右移的符号位是1,那么仍然用0来补高位

时间: 2024-12-20 01:54:47

逻辑运算和位运算的相关文章

逻辑运算与位运算

$a=0; $b=0; if($a=3||$b=3){  //此时 $a: bool(true),   $b: int(0) $a++;        //true加加无效,还是true $b++; } echo$a.”,”.$b;   //1,1   类型:bool(true), int(1) $a=0; $b=0; If($a=3|$b=3){    //此时 $a: int(3),   $b: int(3) //将3赋给变量b,然后和前面的3做位或运算,结果赋给a $a++; $b++;

嵌入式linux C语言(一)——位运算的使用

嵌入式linux C语言(一)--位运算的使用 ARM是内存与IO统一编址,SoC中有很多控制寄存器,通过对这些寄存器进行位运算对这些控制寄存器进行设置,进而控制外设功能.在修改寄存器某些位的过程中不能修改其他的位. 一.位运算基础 C语言基本的位操作符有与.或.异或.取反.左移.右移六种位运算符.如下表所示: 符号 描述 运算规则 & 与 两个位都为1时,结果才为1 | 或 两个位都为0时,结果才为0 ^ 异或 两个位相同为0,相异为1 ~ 取反 0变1,1变0 << 左移 各二进位

位运算专题

首先抱来Matrix67大牛的文章(修改部分内容): 位运算简介及实用技巧(一):基础篇     去年年底写的关于位运算的日志是这个Blog里少数大受欢迎的文章之一,很多人都希望我能不断完善那篇文章.后来我看到了不少其它的资料,学习到了更多关于位运算的知识,有了重新整理位运算技巧的想法.从今天起我就开始写这一系列位运算讲解文章,与其说是原来那篇文章的follow-up,不如说是一个remake.当然首先我还是从最基础的东西说起. 什么是位运算?    程序中的所有数在计算机内存中都是以二进制的形

位运算 使用技巧

位运算简介及实用技巧(一):基础篇 什么是位运算? 程序中的所有数在计算机内存中都是以二进制的形式储存的.位运算说穿了,就是直接对整数在内存中的二进制位进行操作.比如,and运算本来是一个逻辑运算符,但整数与整数之间也可以进行and运算.举个例子,6的二进制是110,11的二进制是1011,那么6 and 11的结果就是2,它是二进制对应位进行逻辑运算的结果(0表示False,1表示True,空位都当0处理): 110 AND 1011 ---------- 0010  -->  2 由于位运算

位运算简介及实用技巧(一):基础篇[转]

位运算简介及实用技巧(一):基础篇 原贴链接:http://www.matrix67.com/blog/archives/264 去年年底写的关于位运算的日志是这个Blog里少数大受欢迎的文章之一,很多人都希望我能不断完善那篇文章.后来我看到了不少其它的资料,学习到了更多关于位运算的知识,有了重新整理位运算技巧的想法.从今天起我就开始写这一系列位运算讲解文章,与其说是原来那篇文章的follow-up,不如说是一个remake.当然首先我还是从最基础的东西说起. 什么是位运算?    程序中的所有

(转)位运算简介及使用技巧

转自http://www.matrix67.com/blog/archives/263 去年年底写的关于位运算的日志是这个Blog里少数大受欢迎的文章之一,很多人都希望我能不断完善那篇文章.后来我看到了不少其它的资料,学习到了更多关于位运算的知识,有了重新整理位运算技巧的想法.从今天起我就开始写这一系列位运算讲解文章,与其说是原来那篇文章的follow-up,不如说是一个remake.当然首先我还是从最基础的东西说起. 什么是位运算?    程序中的所有数在计算机内存中都是以二进制的形式储存的.

位运算(&amp;amp;、|、^)与逻辑运算(&amp;amp;&amp;amp;、 ||)差别

刚无意在一篇文章中看到了位运算(&.|)和逻辑运算(&&.||)的介绍.想起了自己薄弱的基础知识.于是百度了几把总结了下. 首先从概念上区分下,位运算是将运算符两边的数字换算成二进制(例:0000010001)后比較同样位置上的0.1进行运算的.逻辑运算即比較运算符两边的逻辑值(true或false).概念比較抽象.下边借助实际样例比較下. 位运算 先将每一个数转换成二进制.然后进行.位或(|)表示相相应的每位至少有一个为1.则结果为1,仅仅有两个都为0.结果才为0.位与(&

位运算(&amp;、|、^)与逻辑运算(&amp;&amp;、 ||)区别

刚无意在一篇文章中看到了位运算(&.|)和逻辑运算(&&.||)的介绍,想起了自己薄弱的基础知识,于是百度了几把总结了下. 首先从概念上区分下,位运算是将运算符两边的数字换算成二进制(例:0000010001)后比较相同位置上的0.1进行运算的.逻辑运算即比较运算符两边的逻辑值(true或false).概念比较抽象,下边借助实际例子比较下. 位运算 先将每个数转换成二进制,然后进行,位或(|)表示相对应的每位至少有一个为1,则结果为1,只有两个都为0,结果才为0.位与(&)

Java 位运算(移位、位与、或、异或、非)与逻辑运算

java 位运算包括:左移( << ).右移( >> ) .无符号右移( >>> ) .位与( & ) .位或( | ).位非( ~ ).位异或( ^ ),除了位非( ~ )是一元操作符外,其它的都是二元操作符. 逻辑运算符&.&&.|.||: 一.逻辑&与短路&&的区别 总的来说区别是体现在,只有这两个运算符的左边为false的时候会有区别,看如下代码 1.逻辑&的运算 boolean a = tr