关于int的范围以及溢出问题
最近在练一些算法题目的时候恰巧碰到了几道关于int范围与溢出相关的问题,于是就整理一下。
1、原码、补码
在计算机中数值都是用补码表示和存储的(正数补码与原码一致,负数补码是原码符号位不变,其余位取反,然后+1即反码+1)。
可以通过将这个数每一位和1做&运算得到具体的二进制表示,代码如下。代码部分参考https://blog.csdn.net/youyou362/article/details/72667951
- /**
- * 将n的每一位与1做&运算 得到具体的二进制表示
- * @param n
- * @return
- */
- public static void converseToBinary(int n) {
- int value = 1;
- int[] arr = new int[32];
- int i = 31;
- while (value != 0) {
- if ((value & n) != 0) {
- arr[i] = 1;
- } else {
- arr[i] = 0;
- }
- i--;
- value = value << 1; //左移右边补0,当移完32为value为0.
- }
- for (int index = 0;index < 32;index++){
- System.out.print(arr[index]);
- if ((index+1)%4 == 0){
- System.out.print(" ");
- }
- }
- }
例如-3,程序运行结果为 1111 1111 1111 1111 1111 1111 1111 1101 ,正是-3的补码。由此得知在计算机中数值都是用补码表示和存储的。
2、int的取值范围
java中int四字节,一个字节8bit所以 int 32bit 即高16位和低16位,共32位,最高位符号位。
在Integer类中,有两个常量 MIN_VALUE和MAX_VALUE是16进制的数。
- /**
- * A constant holding the minimum value an {@code int} can
- * have, -2<sup>31</sup>.
- */
- @Native public static final int MIN_VALUE = 0x80000000;
- /**
- * A constant holding the maximum value an {@code int} can
- * have, 2<sup>31</sup>-1.
- */
- @Native public static final int MAX_VALUE = 0x7fffffff;
转化成二进制分别是MIN_VALUE = 1000 0000 0000 0000 0000 0000 0000 0000;
MAX_VALUE = 0111 1111 1111 1111 1111 1111 1111 1111;
网上看了好多文档,关于最大值和最小值为什么是这两个写的挺模棱两可的,一开始我猜想正数最大值的时候是因为一共32位,第一位符号位0,剩下都应该是1才是最大,得到正好是0111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111,即2^31 - 1,但已这种方式推算负数最大值时进行不下去,于是用数学归纳法进行总结:
正数部分:1的补码为 0000 0000 0000 0000 0000 0000 0000 0001;
2的补码为0000 0000 ............................................. 0010 ;
3的补码为 0000 0000 ............................................. 0011;
由此推出正数最大值的补码为 0111 1111 1111 1111 .......................1111,原码=补码,为2^31-1;
负数部分:-1的补码为 1111 1111 1111 1111 1111 1111 1111 1111
-2的补码为 1111 1111 1111 1111 1111 1111 1111 1110
-3的补码为 1111 1111 1111 1111 1111 1111 1111 1101
-4的补码为 1111 1111 1111 1111 1111 1111 1111 1100
由此推出负数最小值的补码为 1000 0000 0000 0000 0000 0000 0000 0000 0000,求负数最小值补码的原码为-2^31
所以int的范围为-2^31 ~ 2^31-1
3、int的溢出问题,参考自https://www.jianshu.com/p/ffc97c4d2306
溢出是针对有符号数的。
int最大值为 2^31 - 1 补码为 0111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 加1为 1000 0000 0000 ................0000有溢出,为-2^31
int最小值 -2^31 补码为 1000 0000 0000 0000 0000 0000 0000 0000 0000 ,-2^31 - 1为加-1的补码1111 1111 1111 1111 1111 1111 1111 1111
溢出为 1 0111 1111 1111 1111 11111 1111 1111 1111为 2^31 - 1。
本人只是个小白,以上只是个人拙见,如果有问题还请大家指出,有更好的想法欢迎大家留言,一起进步,谢谢!
关于int的范围以及溢出问题的更多相关文章
- 将 expression 转换为数据类型 int 时发生算术溢出
将 expression 转换为数据类型 int 时发生算术溢出错误 2种快速处理方法 1.CONVERT(bigint, 字段名): 2.Cast(字段名 as decimal(18,2)): 这个 ...
- 将 IDENTITY 转换为数据类型 int 时出现算术溢出错误。
IDENTITY标识列为int类型,取值范围为-2^32到2^31-1.当增长值超过这个最大值时,我在SQL Server 2008 R2 x64上试验的结果是: 将 IDENTITY 转换为数据类型 ...
- sql servel 报错:将 expression 转换为数据类型 int 时出现算术溢出错误。
执行sql语句:SELECT AVG( DATEDIFF(s,s.CreatedDate,s.SendDate) ) AS submitTime FROM dbo.SmsSend AS s ...
- 将expression转化为数据类型int时发生算术溢出错误
在SQL Server 中,某列的数据都在int范围之内,但是使用sum聚集函数求该列和的时候,出现“将expression转化为数据类型int时发生算术溢出错误”. 问题在于定义的数据类型: 首先, ...
- 两个int的和判断溢出
long a,b; cin>>a>>b; long i; i = a+b; if((i^a)<0 && (i^b)<0) cout<<& ...
- 【转载】小心 int 乘法溢出!
C/C++ 语言里, 绝大部分平台上 int 类型是 32 位的, 无论你的操作系统是否是 64 位的. 而一些常用的函数, 如 malloc(), 它接受的参数是 size_t 类型: void * ...
- C#中(int)、int.Parse()、int.TryParse()和Convert.ToInt32()的区别
转自:http://www.cnblogs.com/leolis/p/3968943.html 在编程过程中,数据转换是经常要用到的,C#中数据转换的方法很多,拿将目标对象转换为 整型(int)来讲, ...
- C#中(int)、int.Parse()、int.TryParse()和Convert.ToInt32()的区别 <转>
作者:Statmoon 出处:http://leolis.cnblogs.com/ 在编程过程中,数据转换是经常要用到的,C#中数据转换的方法很多,拿将目标对象转换为整型(int)来讲,有四种方法 ...
- (int)、int.Parse()、int.TryParse()和Convert.ToInt32()的区别
C#中(int).int.Parse().int.TryParse()和Convert.ToInt32()的区别 原文链接:http://www.cnblogs.com/leolis/p/3968 ...
随机推荐
- git rebase VS git merge? 更优雅的 git 合并方式值得拥有
写在前面 如果你不能很好的应用 Git,那么这里为你提供一个非常棒的 Git 在线练习工具 Git Online ,你可以更直观的看到你所使用的命令会产生什么效果 另外,你在使用 Git 合并分支时只 ...
- 实例解说AngularJS在自动化测试中的应用
一.什么是AngularJS ? 1.AngularJS是一组用来开发web页面的框架.模板以及数据绑定和丰富UI的组件: 2.AngularJS提供了一系列健壮的功能,以及将代码隔离成模块的方法: ...
- 多线程总结-同步之volatile关键字
目录 1 案例引出可见性 2 案例引出原子性 1 案例引出可见性 代码解析:新起一个子线程执行m()方法,1秒后主线程将b置为false,子线程是否会停止执行死循环while(b){},打印" ...
- Specifying the Code to Run on a Thread
This lesson shows you how to implement a Runnable class, which runs the code in its Runnable.run() m ...
- @ImportResource导入的xml配置里的Bean能够使用@PropertySource导入的属性值吗?
每篇一句 大师都是偏执的,偏执才能产生力量,妥协是没有力量的.你对全世界妥协了你就是空气.所以若没有偏见,哪来的大师呢 相关阅读 [小家Spring]详解PropertyPlaceholderConf ...
- python函数知识一 函数初始、定义与调用、返回值、参数和函数的好处+菜中菜
第四章 函数 1.函数初识: def :关键字 -- 定义 函数名:和变量的定义方式一样 (): 用于参数传递,: 形参:函数的定义中()内的是形参 实参:调用的()内是实参 传参:调用时将实参传递给 ...
- 百度OCR文字识别API使用心得===com.baidu.ocr.sdk.exception.SDKError[283604]
异常com.baidu.ocr.sdk.exception.SDKError[283604]App identifier unmatch.错误的packname或bundleId.logId::303 ...
- Android使用webService(发送xml数据的方式,不使用jar包)
Android使用webService可以用ksoap2.jar包来使用.但是我觉得代码不好理解,而且记不住. 所以我查询了好多资料,以及自己的理解.可以用代码发送http请求(发送xml数据)来访问 ...
- [PTA] 1001. 害死人不偿命的(3n+1)猜想 (Basic)
import java.util.*; public class Main { public static void main(String[] args) { Scanner sc = new Sc ...
- python购物车升级版
各文件内容 前言 功能架构等请参考前一篇博客,此篇博客为进阶版的存代码展示. 详细文件内容 启动文件 starts.py启动文件 import os import sys BASE_DIR = os. ...