计算机编码:

  • 原码

符号位为0表示正数,为1表示负数;

其余各位等同于真值的绝对值。

如:0000 0000 0000 0010 =2,1000 0000 0000 0010 =-2

  • 反码

符号位的用法及正数的表示与“原码”一样;

负数的表示是在“原码”表示的基础上通过将符号位以外的各位取反来获得的。

如:0000 0000 0000 0010 = 2,1111 1111 1111 1101 = -2

  • 补码

符号位的用法及正数的表示与“原码”一样;

负数的表示是在“反码”的基础上通过加1来获得的。

如:0000 0010 = 2,1111 1110 = -2

计算机中负数的表示均用补码,负数参与的运算得到的也是补码

位运算符:

& 与。    全1为1, 有0为0。  任何数与0与都等于0。  

| 或。      有1为1, 全0为0。  任何数与0或都等于原值。

~ 非。     逐位取反

^ 异或。  相同为0,相异为1。      任何数与0异或都等于原值。

Java基本类型的字节长度

java基本类型的的字节长度与具体的软硬件环境无关。Java中的char类型用Unicode码储存。

各个类型长度为:

byte : 1

short : 2

char : 2

int : 4

long : 8

float : 4

double: 8

boolean : 1

java各个类型的二进制编码实例(System.out.println(Integer.toBinaryString(i));)

int i = 1;

二进制表示为:(原码)

00000000 00000000 00000000 00000001

int i = -1;

二进制表示为:(补码)

11111111 11111111 11111111 11111111

long l = 1;

二进制表示为:

00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000001

特别注意:

负数都是用补码表示并参与运算的。得到的也是补码,需要减1取反获得原码。

位运算事例

-1^1,

-1

1000 0000 0000 0000 0000 0000 0000 0001--原码

1111 1111 1111 1111 1111 1111 1111 1110--反码

1111 1111 1111 1111 1111 1111 1111 1111--补码

1

0000 0000 0000 0000 0000 0000 0000 0001--原码

则-1^1等于

1111 1111 1111 1111 1111 1111 1111 1111^

0000 0000 0000 0000 0000 0000 0000 0001=

1111 1111 1111 1111 1111 1111 1111 1110--补码

1111 1111 1111 1111 1111 1111 1111 1101--反码

1000 0000 0000 0000 0000 0000 0000 0010--原码

即-1^1=-2

移位运算:

  • 逻辑左移 <<

右边补0,符号位就是被移动到的位.

正数:

x<<1一般相当于2x,但是可能溢出.

若x在这个范围中: 2的30次方~(2的31次方-1) 二进制表示 0100...0000到0111...1111,<<后最高为变为1了,变成负数了.

负数:

x<<1一般也相当于2x,也有可能溢出.

若x在这个范围中: -2的31次方~-(2的30次方+1)二进制表示1000...0000到1011...1111,<<后最高为变成0了,变成正数了.

  • 算术右移 >>

为正数时左边补0,为负数时左边补1.

x>>1,相当于x/2,余数被舍弃,因为这个是缩小,所以不会溢出.

不过有一点要注意: -1右移多少位都是-1.(因为负数都是用补码表示,-1永远是 11111...)

另外舍弃的余数是正的:

3>>1=1  舍弃的余数是1.

-3>>1=-2 舍弃的余数也是1,而不是-1.

对于正数 x>>1和x/2相等

对于负数 x>>1和x/2不一定相等.

  • 逻辑右移 >>>

这个把符号位一起移动,左边补0

对于正数,>>>和>>是一样的

对于负数,右移之后就变成正数

对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。

但在进行逻辑右移位时,也可能遇到一个问题。若对byte或short值进行右移位运算,

得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。

但“零扩展”不会发生,所以在那些情况下会得到-1的结果。

 

  1.            int i = -1;
  2.  
  3. i >>>= 10;
  4.  
  5. System.out.println(i);
  6.  
  7. System.out.println(Integer.toBinaryString(i));
  8.  
  9. long l = -1;
  10.  
  11. l >>>= 10;
  12.  
  13. System.out.println(l);
  14.  
  15. System.out.println(Long.toBinaryString(l));
  16.  
  17. short s = -1;
  18.  
  19. s >>>= 10;
  20.  
  21. System.out.println(s);
  22.  
  23. System.out.println(Integer.toBinaryString(s));
  24.  
  25. byte b = -1;
  26.  
  27. b >>>= 10;
  28.  
  29. System.out.println(b);
  30.  
  31. System.out.println(Integer.toBinaryString(b));

输出结果

  1. 4194303
  2.  
  3. 0000 0000 0011 1111 1111 1111 1111 1111
  4.  
  5. 18014398509481983
  6.  
  7. 0000 0000 0011 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111
  8.  
  9. -1
  10.  
  11. 1111 1111 1111 1111 1111 1111 1111 1111
  12.  
  13. -1
  14.  
  15. 1111 1111 1111 1111 1111 1111 1111 1111

一道诡异的移位题

int i=-1;
  int j=i>>>32;
  System.out.println(j);

输出结果为 -1

JAVA进行移位运算中因为int是占32位,进行移位的数是32的模,所以当i>>>32的时候就等于i>>>0,相当于没有进行移位.

位运算及在java中的应用整理的更多相关文章

  1. 位运算解决“一个数组中,只有一个数字出现n次,其他数字出现k次”问题

    转自:https://blog.csdn.net/monster_girl/article/details/52928864 在学习完位操作后,经常会遇到一类关于查找缺失整数的问题. 第一类是给你一个 ...

  2. java中的IO整理

    写在前面:本文章基本覆盖了java IO的全部内容,java新IO没有涉及,因为我想和这个分开,以突出那个的重要性,新IO哪一篇文章还没有开始写,估计很快就能和大家见面.照旧,文章依旧以例子为主,因为 ...

  3. java中反射学习整理

    转载请注明:http://blog.csdn.net/j903829182/article/details/38405735 反射主要是指程序能够訪问.检測和改动它本身的状态或行为的一种能力. jav ...

  4. java中的反射整理

    1,什么是反射 反射机制是java语言提供的一种基础功能,它能够赋予成语在运行时进行自省的能力.通过反射我们可以直接操作类或者对象,例如:可以通过反射去获取某个对象的类的定义,属性,方法,还可以修改类 ...

  5. java中的String整理

    基础知识模块: 参考以下博客,写得很好,深入分析了String,需要重点掌握 http://www.tiantianbianma.com/java/java-basic/page/3/ http:// ...

  6. 【转】 Java中的IO整理

    写在前面:本文章基本覆盖了java IO的全部内容,java新IO没有涉及,因为我想和这个分开,以突出那个的重要性,新IO哪一篇文章还没有开始写,估计很快就能和大家见面.照旧,文章依旧以例子为主,因为 ...

  7. Java中Iterator用法整理

    迭代器(Iterator) 迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构.迭代器通常被称为“轻量级”对象,因为创建它的代价小. Java中的I ...

  8. Java中vector用法整理

    ArrayList会比Vector快,他是非同步的,如果设计涉及到多线程,还是用Vector比较好一些 import java.util.*; /** * 演示Vector的使用.包括Vector的创 ...

  9. Java中并发问题整理

    1. java中有几种方法可以实现一个线程? 使用Runnable,Callable,Thread或者线程池 2. 如何停止一个正在运行的线程? 可以使用正在运行的线程,支持线程中断,通常是定义一个v ...

随机推荐

  1. linux动态库加载的秘密

    摘自http://gotowqj.iteye.com/blog/1926734 摘自http://www.360doc.com/content/14/0313/13/12747488_36024641 ...

  2. Java List 汉字进行排序

    Comparator<Person> cmp = new Comparator<Person>() { public int compare(Person o1, Person ...

  3. A. Anton and Letters

    time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...

  4. Android Service 系统服务

    android sdk 提供很多公用的服务,也就是系统服务,开发者可以通过Activity类的getSystemService方法获取指定的服务.系统服务包含音频服务.视频服务窗口服务等.本篇主要讲T ...

  5. RDLC报表系列(四) 矩阵

    继续接上一篇的内容,本文主要是讲矩阵的内容 用到的数据源如下: DataTable dt = new DataTable(); dt.Columns.Add("FiscalYear" ...

  6. java中使用URLClassLoader访问外部jar包的java类

    很多时候 我们写的Java程序是分模块的,有很好的扩展机制,即我们可以为我们自己的java类添加插件,来运行将来某天我们可能开发出来的类,以下称这些类为插件类. 下边是一种简单的实现方法: Class ...

  7. SQL Server 死锁检查

    示例代码 select spid, blocked, status, hostname, program_name, hostprocess, cmd from sysprocesses -- kil ...

  8. C语言静态函数静态变量

    C语言程序可以看成由一系列外部对象构成,这些外部对象可能是变量或函数.而内部对象是指定义在函数内部的函数参数及变量. 外部变量定义在函数之外,因此可以在许多函数中使用.由于C语言不允许在一个函数中定义 ...

  9. 开博第二篇:记一个利用JavaScript,编写PS脚本,开发图片量产工具

    背景:身在一个有实业的电商公司,设计部的妹子们总是会有做不完的商品图片,当然了,要是做点有技术含量的美化工作也罢,但是最近她们很是无聊,总是要做一些重复性的工作,就比如如题所说的,图片量产,量产什么呢 ...

  10. sqlmap新手注入

    一 什么是sqlmap sqlmap is an open source penetration testing tool that automates the process of detectin ...