热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java之Integer知识整理

最近本人在看jdk源代码的时候很有感触,感叹代码是如此的精炼。就好比说这个最容易被忽视的Integer。Integer是对int类型的封装,这点大家

 最近本人在看jdk源代码的时候很有感触,感叹代码是如此的精炼。就好比说这个最容易被忽视的Integer。Integer是对int 类型的封装,这点大家都知道。今天我尝试来分析其部分本人认为比较有意思的源代码。

    1 如何来找一个整数中其所对应的二进制数值中,最高位1所代表的数值。例如01000。代表的是8

   
 public static int highestOneBit(int i) {
i |= (i >> 1);
i |= (i >> 2);
i |= (i >> 4);
i |= (i >> 8);
i |= (i >> 16);
return i - (i >>> 1);
}

     代码解析:因为int类型是4个字节,也就是32位。当我们完成以上操作的时候,就能够保证最高位1后的低位数值全都位1。然后用i-(i>>>1)。这样就得到值了。注意这里一定要i>>>1。因为i有可能为负数。
  2 如何来找一个整数中其所对应的二进制数值,最低位1所代表的数值。例如0101代表的值是2。    这里先说一下思路,假设这个二进制值是00111xxxxx。这个xxxxxx代表的是0或者没有。大多数人都知道负数的二进制码也就是补码是反码+1。补码&反码的值肯定为0。那和反码加1呢。这里分为两种情况。如果xxxx没有占用位数。也就是001111是最后的几位。那得到的是1。如果说xxxxx占用位数,那反码后得到的值也全都是1。然后加1。 所以代码非常简单。
    public static int lowestOneBit(int i) {
return i & -i;
}

3  如何查找最高位1是第几位。   这里实现的思路是最高为1前面有几个0。然后用32-。 
public static int numberOfLeadingZeros(int i) {
// Hacker's Delight, Figure 5-6
if (i <= 0) {
return (~i >> 26) & 32;
}
int n = 1;
if (i >> 16 == 0) {
n += 16;
i <<= 16;
}
if (i >> 24 == 0) {
n += 8;
i <<= 8;
}
if (i >> 28 == 0) {
n += 4;
i <<= 4;
}
if (i >> 30 == 0) {
n += 2;
i <<= 2;
}
return n - (i >>> 31);
}
 代码解析:1  如果i为负数,则返回值为0。                      2 如果是正数。总体的思路就是逐步的判断最高位1的位置。采用类似二分法。所采用的二分点在最高位1所可能在的区域。按照流程走一遍。                       1 先把这个数值向右移动16位,如果说等于0。说明最高位1位于低16位数值。然后把这个值往左移动16位。                         如果说大于0。说明这个最高位1位于高16位中的某一位。                         按照这样的思路,我们就是在可能的区域中,然后取中间那个数,往右移动作比较。(对不起描述的不是很好)          这里要注意一点就是n初始值是为1的。就是假设经过以上步骤后,i>>>31得到的也为0。所以最终的值为:n-(i>>>31)                         这里得到的数值是最高位1前面0的个数。                        然后你32减所得到的值就是了。
4 给定一个数值a,找出一个比a大或者等于的最小的2的幂数值。比如说7的时候,找到值8. 实现代码如下:
public static int roundUpToPowerOfTwo(int i) {
i--;

i |= i >>> 1;
i |= i >>> 2;
i |= i >>> 4;
i |= i >>> 8;
i |= i >>> 16;

return i + 1;
}


减1的目的是防止i就是一个符合条件的数值。比如说8.分析的方法,跟前面一个样。


推荐阅读
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • Java中处理大数据问题(BigInteger、BigDecimal)
    原文转自:https:blog.csdn.netzhongkeleearticledetails52289163;http:www.cnblogs.c ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 配置IPv4静态路由实现企业网内不同网段用户互访
    本文介绍了通过配置IPv4静态路由实现企业网内不同网段用户互访的方法。首先需要配置接口的链路层协议参数和IP地址,使相邻节点网络层可达。然后按照静态路由组网图的操作步骤,配置静态路由。这样任意两台主机之间都能够互通。 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • 本文讨论了在VMWARE5.1的虚拟服务器Windows Server 2008R2上安装oracle 10g客户端时出现的问题,并提供了解决方法。错误日志显示了异常访问违例,通过分析日志中的问题帧,找到了解决问题的线索。文章详细介绍了解决方法,帮助读者顺利安装oracle 10g客户端。 ... [详细]
  • SCJP认证全称为SUN认证Java程序员,是Java认证系列中最基础的一门认证。要通过Java的其他认证,必须先通过SCJP认证(SCEA认证除外)。即使SUN被Oracle收购 ... [详细]
  • 一、MyEclipse中的一些常用的快捷键:ctrl+shift+x大写ctrl+shift+y小写alt+内容提示写住方法的时候可以先写main然后按alt+就可以了ctrl+1 ... [详细]
  • 文章来源:http:www.blogjava.netchangchengarchive20100304314515.html我们编写的是Andorid的 ... [详细]
  • Integer类基本类型int的封装类,是不可变类。该类提供了很多与int相互转换的方法。int类型32位,因此它有最小值(-2^31-2147483648)和最大值(2^31-1 ... [详细]
  • 多数java程序员都非常清楚使用jar文件将组成java解决方案的各种资源(即.class文件、声音和图像)打包的优点。刚开始使用jar文件的人常问的一个问题是:&ldquo ... [详细]
author-avatar
vivi_康冬薇
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有