博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java中的位操作
阅读量:5276 次
发布时间:2019-06-14

本文共 1510 字,大约阅读时间需要 5 分钟。

之前做项目的时候使用位操作不是很多,今天在刷leetcode上题目的时候用到了位操作,是leetcode中的第29题。

一、java的位操作:

位运算表达式由操作数和位运算符组成,实现对整数类型的二进制数进行位运算。位运算符可以分为逻辑运算符(包括~、&、|和^)及移位运算符(包括>>、<<和>>>)。

1)左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。左移一位(在不溢出的情况下)相当于乘以2。 

2)“有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。 “有符号”右移位运算符使用了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。右移一位相当于除以2。

3)Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0。

4)若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。 只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。 若对一个long值进行处理,最后得到的结果也是long。在leetcode这道题目里面需要用到的类型是long。

5)在这6种操作符,只有~取反是单目操作符,其它5种都是双目操作符。

二、java位操作的实际操作:

我们从其他博客里面看到的位操作的举例往往都是给一个数字,然后通过syso进行输出操作。

程序:public class PlusRightMoving{    public static void main(String[] args){           System.out.println("5>>1="+(5>>1));    }}输出结果:5>>1=2

但是需要注意的是,如果进行赋值操作和C/C++中是不一样的。

在C/C++中进行左移和右移操作:

div << 1;res << 1;

但是在java中进行位移操作需要配合赋值操作:

long div = 1;long res = 1;while(div < dived){    div = div << 1;    res = res << 1;}    if(div != dived){    div = div >> 1;    res = res >> 1;}

如果只是像C/C++中进行操作一样,会不能编译通过。

三、位操作的一些应用题:

1)判断奇偶

只要根据最未位是0还是1来决定,为0就是偶数,为1就是奇数。因此可以用if ((a & 1) == 0)代替if (a % 2 == 0)来判断a是不是偶数。下面程序将输出0到100之间的所有偶数。

2)交换两数

int c = 1, d = 2; 

c ^= d; 
d ^= c; 
c ^= d; 
System.out.println(“c=” + c); 
System.out.println(“d=” + d);

3)变换符号

 

如对于-11和11,可以通过下面的变换方法将-11变成11

 

1111 0101(二进制) –取反-> 0000 1010(二进制) –加1-> 0000 1011(二进制)

 

同样可以这样的将11变成-11

 

0000 1011(二进制) –取反-> 0000 0100(二进制) –加1-> 1111 0101(二进制)

其他的应用可以参考博客文章:

其中有很多对java位操作的应用介绍。

 

转载于:https://www.cnblogs.com/winterfells/p/7596877.html

你可能感兴趣的文章
2012-01-12 16:01 hibernate注解以及简单实例
查看>>
iOS8统一的系统提示控件——UIAlertController
查看>>
PAT甲级——1101 Quick Sort (快速排序)
查看>>
python创建进程的两种方式
查看>>
1.2 基础知识——关于猪皮(GP,Generic Practice)
查看>>
迭代器Iterator
查看>>
java易错题----静态方法的调用
查看>>
php建立MySQL数据表
查看>>
最简单的线程同步的例子
查看>>
旅途上看的电影和观后感
查看>>
Ztree异步树加载
查看>>
关于IE和火狐,谷歌,Safari对Html标签Object和Embed的支持问题
查看>>
poj3320 Jessica's Reading Problem(尺取思路+STL)
查看>>
分布式计算开源框架Hadoop介绍
查看>>
安卓平台接口剖析
查看>>
坏的事情不都会带来坏的结果
查看>>
RPC的基础:调研EOS插件http_plugin
查看>>
第二次团队冲刺第二天
查看>>
bzoj 2257 (JSOI 2009) 瓶子与燃料
查看>>
11)Java abstract class 和 interface
查看>>