java int是什么
在Java中,int是使用32位表示,long使用64位表示。这两个基本类型都是整形,没有其他的表示方法了。他们内部是怎么表示的呢?是采用补码表示。由于我们经常在做题中会遇到Java的位运算,Java的位运算只能用于int和long型。所以我们有理由好好分析Java内部是怎么用二进制表示的。这里只举int为例子,long是一样的。
1、int的范围
int在Java内部是用32位来表示的,而最高位是表示符号,因此真正可以表示数字的是31位。Java的int类型取值范围是-2^31~2^31-1.
为什么范围是这样?这就涉及到二进制的存储方法了。
在Java中,是使用补码来存储int。对于一个正数,其补码,就是本身。例如,我们举4个位来做例子。对于正数1-7,分别是0001,0010,。。。,0111,一共是7个数字,也就是2^3-1个。
对于0,可以看到问题来了。可以是-0,也可以是+0,都是0。决定要怎么表示0呢?补码的法则规定,0认为是+0,因此0用0000表示。
这个时候,需要表示负数了。我们认为,一个负数,它的补码表示是其绝对值取反(连同符号位一起取反)再加1。例如,对于-5,它的绝对值是5,表示为0101,取反,为1010,加一为1011,这就是-5的补码表示。
这个时候,可以用1000来表示-8,于是负数的范围是-2^31,这也就解释了int的取值范围。对于64位的long也是完全一样的。
2、Java的位运算
Java的位运算是怎么做的呢?要记住,移位运算是整个数整体向左或者右移动。如果是向左移,则是低位补0。如果是向右移,分两种情况。如果是0和正数,则高位补0。如果是负数,则高位补1。如对于-5为1011,右移一位为1101,也就是-3。
还有一种位运算。如果是按位运算,记得符号位也是要参与进来的!
3、右移与除法的关系
对于正数(当然0也是)来说,右移一位等于除以2的结果,但是对于负数来说不是(确切地说是除以2的结果-1)!例如,-5/2结果是-2,-5>>1结果是-3。
4、正负号与整数除法、取余运算的关系
正数/正数,向下取整
负数/负数,等于他们的绝对值相除
正数/负数和负数/正数,就是他们绝对值相除乘上负号。
至于%的结果,结果的绝对值与他们绝对值的取余一样,但是符号由第一个数决定。
5、为什么要用补码?
(1)前面已经说过,为了合理地表示+0和-0;
(2)可以在负数处多表示一个最负的数;
(3)使用补码,可以将符号位和其它位统一处理;同时,减法也可按加法来处理。另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。
其实很大一个原因是为了计算加减法方便。在使用补码系统进行运算的时候,是可以把符号位加起来一起运算的。在位运算中,如果符号位有进位,是可以舍弃的,因为已经超出了比特范围了。对于正数和正数相加,没什么特别的。下面例子都是8个比特的。例如,对于7+7,也就是00000111+00000111,结果是00001110,为14。
而对于减法,例如9-4,我们就认为是9+(-4),先对4,也就是00000100取反再加一,得到-4的补码表示11111100,然后相加,也就是
+00001001(9)
+11111100(-4)
? 100000101
最后一位符号位的进位1,因为已经超出了比特范围,所以直接舍弃,可以直接就得到5了。所以这也就是实现了减法变加法。
以上是java int是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Java的类上载涉及使用带有引导,扩展程序和应用程序类负载器的分层系统加载,链接和初始化类。父代授权模型确保首先加载核心类别,从而影响自定义类LOA

本文讨论了使用咖啡因和Guava缓存在Java中实施多层缓存以提高应用程序性能。它涵盖设置,集成和绩效优势,以及配置和驱逐政策管理最佳PRA

本文使用lambda表达式,流API,方法参考和可选探索将功能编程集成到Java中。 它突出显示了通过简洁性和不变性改善代码可读性和可维护性等好处

本文讨论了使用JPA进行对象相关映射,并具有高级功能,例如缓存和懒惰加载。它涵盖了设置,实体映射和优化性能的最佳实践,同时突出潜在的陷阱。[159个字符]

本文讨论了使用Maven和Gradle进行Java项目管理,构建自动化和依赖性解决方案,以比较其方法和优化策略。

本文使用选择器和频道使用单个线程有效地处理多个连接的Java的NIO API,用于非阻滞I/O。 它详细介绍了过程,好处(可伸缩性,性能)和潜在的陷阱(复杂性,

本文使用Maven和Gradle之类的工具讨论了具有适当的版本控制和依赖关系管理的自定义Java库(JAR文件)的创建和使用。

本文详细介绍了用于网络通信的Java的套接字API,涵盖了客户服务器设置,数据处理和关键考虑因素,例如资源管理,错误处理和安全性。 它还探索了性能优化技术,我
