java中的移位运算符与正负数转换
2016-05-04 17:25
363 查看
移位
java 中有对 二进制移动分为 左移(<<) 和右移(>>)
其中右移还分为 有符号右移(>>) 和无符号右移(>>>)
1.有符号右移:将二进制向右移动 如果原来符号位为0 则新符号位也用0 否则用1;
2.无符号右移:将二进制向右移动 不管原来的符号位是0还是1 一律用0 补位;
正负数转换
举个例子:
3的二进制 用一个字节表示
0000 0011
正常一个负数的变现方式是:其正数按位取反再加1
0000 0011
取反:1111 1100
加一:1111 1101(这就是-3的二进制表现形式)
但有更快捷的转换方法:
二进制从左向右看 最后一个 1不变,其余全部取反
0000 0011 (3)
1111 1101 (-3)
后补知识:
一个byte类型负数转换为整型时 其他的24位均用1 来填充, 正数则用0来填充. 如果想让负数也使用0来填充,就得先用这个负数与0xFF相与 再转换为int类型就ok了
java 中有对 二进制移动分为 左移(<<) 和右移(>>)
其中右移还分为 有符号右移(>>) 和无符号右移(>>>)
1.有符号右移:将二进制向右移动 如果原来符号位为0 则新符号位也用0 否则用1;
2.无符号右移:将二进制向右移动 不管原来的符号位是0还是1 一律用0 补位;
正负数转换
举个例子:
3的二进制 用一个字节表示
0000 0011
正常一个负数的变现方式是:其正数按位取反再加1
0000 0011
取反:1111 1100
加一:1111 1101(这就是-3的二进制表现形式)
但有更快捷的转换方法:
二进制从左向右看 最后一个 1不变,其余全部取反
0000 0011 (3)
1111 1101 (-3)
后补知识:
一个byte类型负数转换为整型时 其他的24位均用1 来填充, 正数则用0来填充. 如果想让负数也使用0来填充,就得先用这个负数与0xFF相与 再转换为int类型就ok了
相关文章推荐
- Java内存优化和性能优化的几点建议
- Java 容器(一) Arrays
- 79、Java 两个整数相除保留两位小数,将小数转化为百分数
- java基础学习总结——this关键字
- spring mvc获取和返回
- java基础学习总结——哈希编码
- Java加密技术(十)——单向认证
- java基础学习总结——方法的重载(overload)
- Java加密技术(九)——初探SSL
- Java制作证书的工具keytool用法总结
- Java 设计模式 - 桥接模式
- 使用Java实现希尔排序算法的简单示例
- 使用 Eclipse PhoneGap 构建 Android
- Java基础学习总结——Java对象的序列化和反序列化
- Java加密技术(八)——数字证书
- java基础学习总结——抽象类
- java基础学习总结——对象转型
- Java加密技术(七)——非对称加密算法最高级ECC
- java基础学习总结——多态(动态绑定)
- 78、Java Calendar 类的时间操作