java中常见的位运算符:&(逻辑与)  |(逻辑或)  ~(取反)  ^(逻辑异或)  >>(右移)  <<(左移)  >>>(无符号右移)

&(逻辑与):

true&true=true

true&false=false

false&true=false

false&false=false

结论:左右两边同真为真,一假为假。

&还可以用于位运算,位运算都需要换算成二进制进行运算

例:4&6=4

  0100    4

& 0110    6


  0100    4

原理同它的逻辑运算一样,两边都是1的时候为1,有一个是0为0

|(逻辑或):

true&true=true

true&false=true

false&true=true

false&false=false

结论:左右两边一真为真,同假为假。

|还可以用于位运算,位运算都需要换算成二进制进行运算

例:4|6=6

  0100    4

& 0110    6


  0110    6

原理同它的逻辑运算一样,两边都是0的时候为0,有一个是1为1

~(取反)

取反就是把二进制0变成1,1变成0

例:对十进制6进行取反

6---------0000-0000  0000-0000  0000-0000  0000-0110

~


     1111-1111  1111-1111  1111-1111  1111-1001----------这个数就是6取反得到的

^(逻辑异或)

两边相同为false,不同为true

true^true=false

true&false=true

false&true=true

false&false=false

例:8^4=12

8---------0000-0000  0000-0000  0000-0000  0000-1000

4---------0000-0000  0000-0000  0000-0000  0000-0100


     0000-0000  0000-0000  0000-0000  0000-1100

PS:一个数异或同一个数两次,结果还是那个数。  例:8^4^4=8

<<(左移)  左移相当于把该数乘以2的n次方,(n是移动的位数)

例:3<<2=12

就是把3的二进制表现形式整体向左移动两位,右边空位补0

3-----------0000-0000  0000-0000  0000-0000  0000-0011

<<


       0000-0000  0000-0000  0000-0000  0000-1100 -----------12

>>(右移)  右移相当于把该数除以2的n次方,(n是移动的位数)

例:3>>2=0

就是把3的二进制表现形式整体向右移动两位,左边高位空缺,原有最高位是什么,补什么(是0补0,是1补1)

3-----------0000-0000  0000-0000  0000-0000  0000-0011

>>


       0000-0000  0000-0000  0000-0000  0000-0000 -----------0

>>>(无符号右移)   

右移后,高位缺失,不管原有最高位是什么。都补0.

负数二进制表现形式:

就是把该数的正数二进制表现形式取反后+1

以6为例

6---------0000-0000  0000-0000  0000-0000  0000-0110

~


     1111-1111  1111-1111  1111-1111  1111-1001----------这个数就是6取反得到的

+1   0000-0000  0000-0000  0000-0000  0000-0001


     1111-1111  1111-1111  1111-1111  1111-1010----------这个数就是-6

注意:负数的最高位是1,正数的最高位是0。

java基础之位运算的更多相关文章

  1. java ----> 基础之位运算

    package test.ant; import java.util.Arrays; import java.io.UnsupportedEncodingException; public class ...

  2. Java二进制和位运算,这一万字准能喂饱你

    基础不牢,地动山摇.本文已被 https://www.yourbatman.cn 收录,里面一并有Spring技术栈.MyBatis.JVM.中间件等小而美的专栏供以免费学习.关注公众号[BAT的乌托 ...

  3. Java中的位运算

    昨天去面试的时候做到了一道Java的位运算题目,发现有个运算符不懂:">>>",今天特地查了一下,并小结一下常见的位运算符号: ~  按位非(NOT)(一元运算) ...

  4. Java学习之位运算和逻辑运算符

    今天看了一下HashMap类的源码,在HashMap的源码中定义了初始空间的大小 static final int DEFAULT_INITIAL_CAPACITY = 1 << 4; 当 ...

  5. Java 基本数据类型 && 位运算

    1. Java基本数据类型 1.1 数据类型示意图 类型 字节数 范围 byte 1 -128~127 short 2 -32768~32767 int 4 -231~231-1 long 8 -26 ...

  6. [java基础] 002 - 位运算符的详解和妙用

    一:位运算符详解 位运算符主要用来对操作数二进制的位进行运算.按位运算表示按每个二进制位(bit)进行计算,其操作数和运算结果都是整型值. Java 语言中的位运算符分为位逻辑运算符和位移运算符两类, ...

  7. Java中的位运算及简单的算法应用介绍

    众所周知,计算机底层是二进制.而java作为一门计算机编程语言,也对二进制的位运算提供了完整的支持. 在java中,int是32位的,也就是说可以用来实现32位的位运算.方便起见,我们一般用16进制对 ...

  8. day04-Python运维开发基础(位运算、代码块、流程控制)

    # (7)位运算符: & | ^ << >> ~ var1 = 19 var2 = 15 # & 按位与 res = var1 & var2 " ...

  9. java中通过位运算实现多个状态的判断

    通过 <<  |  & ~ 位运算,实现同时拥有多个状态 通过 << 定义数据的状态 public interface LogConstants { /** * 消耗标 ...

随机推荐

  1. Linux 入门笔记

    一开始对linux总有些抵触,黑黑的命令框不知道如何下手,这次因为工作交接的缘故需要负责之前同事的Node后端部分,node,redis这些都是部署在Linux上的,看了几次运维的同学噼里啪啦的敲命令 ...

  2. MySQL两个最简单的delimiter的使用demo

    今天复习MySQL,使用的工具是Navicat for MySQL,写了两个简单的delimiter的demo. 第一个,获取当前时间的年月日时分秒格式的时间: delimiter $$ drop f ...

  3. DateTime.Now的一些用法

    System.DateTime.Now.ToString("D");   //Tuesday, December 13, 2016 System.DateTime.Now.ToSt ...

  4. Azure IoT 技术研究系列4-Azure IoT Hub的配额及缩放级别

    上两篇博文中,我们介绍了将设备注册到Azure IoT Hub,设备到云.云到设备之间的通信: Azure IoT 技术研究系列2-设备注册到Azure IoT Hub Azure IoT 技术研究系 ...

  5. 【WPF】学习笔记(一)——做一个简单的电子签名板

    参加实习(WPF)已经有两个多周的时间了,踩了一些坑,也算积累了一些小东西,准备慢慢拿出来分享一下.(●'◡'●) 这次呢就讲讲一个简单的电子签名板的实现. 先上张图(PS:字写得比较丑,不要太在意哈 ...

  6. C#控制台程序使用Log4net日志组件

    1.Log4net一般都不陌生,但是在配置上不同类型的项目又不相同的地方比如C#控制台程序和C# MVCWeb项目,拿控制台项目为例   项目源码在文章底部 2.首先创建一个控制台程序,引入Log4n ...

  7. Linux 定时任务详解

    原文地址:http://edu.codepub.com/2011/0104/28518.php   crond分为系统级定时和用户级定时,系统级定时主要编辑/etc/crontab,用户级定时主要利用 ...

  8. [js笔记整理]事件篇

    一.事件流1.冒泡事件:从特定的事件到不特定事件依次触发:(由DOM层次的底层依次向上冒泡)(1)示例: <html onclick="add('html<br>')&qu ...

  9. hdu1150 Machine Schedule 经典二分匹配题目

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1150 很经典的二分题目 就是求最小点覆盖集 二分图最小点覆盖集=最大匹配数 代码: #include& ...

  10. POJ3252-Round Numbers 数学

    题目链接:http://poj.org/problem?id=3252 题目大意: 输入两个十进制正整数a和b,求闭区间 [a ,b] 内有多少个Round number 所谓的Round Numbe ...