位运算及在java中的应用整理
计算机编码:
- 原码
符号位为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的结果。
- int i = -1;
- i >>>= 10;
- System.out.println(i);
- System.out.println(Integer.toBinaryString(i));
- long l = -1;
- l >>>= 10;
- System.out.println(l);
- System.out.println(Long.toBinaryString(l));
- short s = -1;
- s >>>= 10;
- System.out.println(s);
- System.out.println(Integer.toBinaryString(s));
- byte b = -1;
- b >>>= 10;
- System.out.println(b);
- System.out.println(Integer.toBinaryString(b));
输出结果
- 4194303
- 0000 0000 0011 1111 1111 1111 1111 1111
- 18014398509481983
- 0000 0000 0011 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111
- -1
- 1111 1111 1111 1111 1111 1111 1111 1111
- -1
- 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中的应用整理的更多相关文章
- 位运算解决“一个数组中,只有一个数字出现n次,其他数字出现k次”问题
转自:https://blog.csdn.net/monster_girl/article/details/52928864 在学习完位操作后,经常会遇到一类关于查找缺失整数的问题. 第一类是给你一个 ...
- java中的IO整理
写在前面:本文章基本覆盖了java IO的全部内容,java新IO没有涉及,因为我想和这个分开,以突出那个的重要性,新IO哪一篇文章还没有开始写,估计很快就能和大家见面.照旧,文章依旧以例子为主,因为 ...
- java中反射学习整理
转载请注明:http://blog.csdn.net/j903829182/article/details/38405735 反射主要是指程序能够訪问.检測和改动它本身的状态或行为的一种能力. jav ...
- java中的反射整理
1,什么是反射 反射机制是java语言提供的一种基础功能,它能够赋予成语在运行时进行自省的能力.通过反射我们可以直接操作类或者对象,例如:可以通过反射去获取某个对象的类的定义,属性,方法,还可以修改类 ...
- java中的String整理
基础知识模块: 参考以下博客,写得很好,深入分析了String,需要重点掌握 http://www.tiantianbianma.com/java/java-basic/page/3/ http:// ...
- 【转】 Java中的IO整理
写在前面:本文章基本覆盖了java IO的全部内容,java新IO没有涉及,因为我想和这个分开,以突出那个的重要性,新IO哪一篇文章还没有开始写,估计很快就能和大家见面.照旧,文章依旧以例子为主,因为 ...
- Java中Iterator用法整理
迭代器(Iterator) 迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构.迭代器通常被称为“轻量级”对象,因为创建它的代价小. Java中的I ...
- Java中vector用法整理
ArrayList会比Vector快,他是非同步的,如果设计涉及到多线程,还是用Vector比较好一些 import java.util.*; /** * 演示Vector的使用.包括Vector的创 ...
- Java中并发问题整理
1. java中有几种方法可以实现一个线程? 使用Runnable,Callable,Thread或者线程池 2. 如何停止一个正在运行的线程? 可以使用正在运行的线程,支持线程中断,通常是定义一个v ...
随机推荐
- linux动态库加载的秘密
摘自http://gotowqj.iteye.com/blog/1926734 摘自http://www.360doc.com/content/14/0313/13/12747488_36024641 ...
- Java List 汉字进行排序
Comparator<Person> cmp = new Comparator<Person>() { public int compare(Person o1, Person ...
- A. Anton and Letters
time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...
- Android Service 系统服务
android sdk 提供很多公用的服务,也就是系统服务,开发者可以通过Activity类的getSystemService方法获取指定的服务.系统服务包含音频服务.视频服务窗口服务等.本篇主要讲T ...
- RDLC报表系列(四) 矩阵
继续接上一篇的内容,本文主要是讲矩阵的内容 用到的数据源如下: DataTable dt = new DataTable(); dt.Columns.Add("FiscalYear" ...
- java中使用URLClassLoader访问外部jar包的java类
很多时候 我们写的Java程序是分模块的,有很好的扩展机制,即我们可以为我们自己的java类添加插件,来运行将来某天我们可能开发出来的类,以下称这些类为插件类. 下边是一种简单的实现方法: Class ...
- SQL Server 死锁检查
示例代码 select spid, blocked, status, hostname, program_name, hostprocess, cmd from sysprocesses -- kil ...
- C语言静态函数静态变量
C语言程序可以看成由一系列外部对象构成,这些外部对象可能是变量或函数.而内部对象是指定义在函数内部的函数参数及变量. 外部变量定义在函数之外,因此可以在许多函数中使用.由于C语言不允许在一个函数中定义 ...
- 开博第二篇:记一个利用JavaScript,编写PS脚本,开发图片量产工具
背景:身在一个有实业的电商公司,设计部的妹子们总是会有做不完的商品图片,当然了,要是做点有技术含量的美化工作也罢,但是最近她们很是无聊,总是要做一些重复性的工作,就比如如题所说的,图片量产,量产什么呢 ...
- sqlmap新手注入
一 什么是sqlmap sqlmap is an open source penetration testing tool that automates the process of detectin ...