【JAVA入门】Day19 - BigInteger 和 BigDecimal

news2024/11/15 16:26:06

【JAVA入门】Day19 - BigInteger 和 BigDecimal


文章目录

  • 【JAVA入门】Day19 - BigInteger 和 BigDecimal
    • 一、BigInteger
      • 1.1 BigInteger 构造方法
      • 1.2 BigInteger 内部常见方法
    • 二、BigDecimal
      • 2.1 BigDecimal 的作用
      • 2.2 BigDecimal 对象的获取
      • 2.3 BigDecimal 中常见的成员方法
      • 2.4 BigDecimal 的底层存储方式


        在 Java 中,整数有四种类型:byte,short,int,long。他们在底层分别占用的字节数如下:

类型占用字节数(byte)
byte1
short2
int4
long8

        当我们想要表示的数字超出 long 的取值范围时,就需要用到 BigInteger 类。

一、BigInteger

1.1 BigInteger 构造方法

方法名说明
public BigInteger(int num, Random rnd)获取随机大整数,范围:[0 ~ 2的num次方-1]
public BigInteger(String val)获取指定的大整数
public BigInteger(String val, int radix)获取指定进制的大整数
public static BigInteger valueOf(long val)静态方法获取BigInteger的对象,内部有优化

        注意:BigInteger 对象一旦创建完毕,里面的数据不能发生改变。

package BigNum;

import java.math.BigInteger;
import java.util.Random;

public class BigIntegerDemo1 {
    public static void main(String[] args) {
        //1.获取一个随机的的大整数
        Random r = new Random();
        BigInteger bd1 = new BigInteger(4, r);     //[0,2^4-1]
        System.out.println(bd1);

        //2.获取一个指定的大整数
        //字符串中,必须是整数,否则会报错
        BigInteger bd2 = new BigInteger("99999999999999999999999999999");
        System.out.println(bd2);

        //3.获取一个指定进制的大整数
        //生成二进制的100,输出时会自动转换为十进制
        //字符串中的数字必须是整数,字符串中的数字必须要和进制吻合,二进制中只能写0和1
        BigInteger bd3 = new BigInteger("100", 2);
        System.out.println(bd3);

        //4.静态方法获取BigInteger的对象,内部有优化
        //能表示的范围比较小,只能在long的取值范围内
        //在内部对常用的数字:-16 ~ 16 进行了优化
        //会提前把 -16 ~ 16 先创建好BigInteger的对象,如果多次获取不会再创建新的对象
        BigInteger bd4 = BigInteger.valueOf(100);
        System.out.println(bd4);

        //验证
        BigInteger bd5 = BigInteger.valueOf(16);
        BigInteger bd6 = BigInteger.valueOf(16);

        System.out.println(bd5 == bd6); //true

        BigInteger bd7 = BigInteger.valueOf(17);
        BigInteger bd8 = BigInteger.valueOf(17);

        System.out.println(bd7 == bd8); //false

        //5.对象一旦创建,内部的数据不能发生改变
        BigInteger bd9 = BigInteger.valueOf(1);
        BigInteger bd10 = BigInteger.valueOf(2);
        BigInteger result = bd9.add(bd10);
        System.out.println(result);    //3
        //add方法把bd9和bd10加起来,此时,不会修改参与计算的BigInteger对象中的值,而是产生了一个新的BigInteger的对象来记录3
        
    }
}

        如果你要创建的数据比较小,建议直接使用静态方法 public static BigInteger valueOf(long val) 来创建对象,会节约内存。

1.2 BigInteger 内部常见方法

在这里插入图片描述

        BigInteger 作为一个对象,是不能直接用基本运算符进行操作的,所有的数学运算,都需要用方法来进行。

package BigNum;

import java.math.BigInteger;

public class BigIntegerDemo2 {
    public static void main(String[] args) {
        //1.创建两个BigInteger对象
        BigInteger bd1 = BigInteger.valueOf(10);
        BigInteger bd2 = BigInteger.valueOf(5);

        //2.加法
        BigInteger bd3 = bd1.add(bd2);
        System.out.println(bd3);

        //3.减法
        BigInteger bd4 = bd1.subtract(bd2);
        System.out.println(bd4);

        //4.除法得到商和余数
        BigInteger[] arr = bd1.divideAndRemainder(bd2);
        System.out.println(arr[0]);
        System.out.println(arr[1]);

        //5.判断两个对象内部数据是否相同
        boolean result = bd1.equals(bd2);
        System.out.println(result);

        //6.次幂
        BigInteger bd5 = bd1.pow(2);

        //7.max
        //max或min方法会直接把较大的那个对象本身返回,并没有创建新的对象
        BigInteger bd6 = bd1.max(bd2);
        System.out.println(bd6 == bd1);     //true
        System.out.println(bd6 == bd2);     //false

        //8.转为int,超出int范围则报错
        BigInteger bd7 = BigInteger.valueOf(2147483647);
        int i  = bd7.intValue();
        System.out.println(i);              //2147483647

        //9.转为long
        BigInteger bd8 = BigInteger.valueOf(2147483648L);
        long l = bd8.longValue();
        System.out.println(l);              //2147483648

        //10.转为double
        BigInteger bd9 = BigInteger.valueOf(100);
        double d = bd9.doubleValue();
        System.out.println(d);              //100.0

    }
}

二、BigDecimal

        计算机中的小数由于存储的方式,导致做运算会出现结果不精确的情况。
在这里插入图片描述
        二进制存储的原理是 2 的次幂和相加,一些不是 2 的倍数的部分就会拆分成多个 2 的次幂相加的形式。如果我们把十进制的小数转换为二进制,后面的小数部分可能变得非常非常长。
        在 Java 中,小数数据类型 float 和 double 的占用字节数是固定的。float 占用 4个字节,也就是 32个bit位;double 占用8个字节,也就是 64个bit位。这些bit位中,还要腾出给整数部分存储的位数,留给小数部分的位数就变成了:float 剩余 23个bit位,double 剩余 52个bit位。超出的部分,只能舍弃。
        上图中,0.226 转换为二进制后,小数部分长达 55 位,已经超过了 double 能装下的最大位数,因此只能舍弃最后3位,因此该数据在计算机中的存储,将变得不精确(失真)
        但是我们在生产生活中,往往需要将小数精确表达,为此,Java 提供了一个精确的小数API——BigDecimal。

2.1 BigDecimal 的作用

  • 存储精确的浮点数
  • 进行浮点数的各种精确操作运算

2.2 BigDecimal 对象的获取

        可以使用构造方法或静态方法获取,用途有别。

package BigNum;

import java.math.BigDecimal;

public class BigDecimalDemo1 {
    public static void main(String[] args) {
        //1.通过传递double类型的小数来创建对象
        //细节:这种方式有可能是不精确的,不建议使用
        BigDecimal bd1 = new BigDecimal(0.01);      //0.01000000000000000020816681711721685132943093776702880859375
        BigDecimal bd2 = new BigDecimal(0.09);      //0.0899999999999999966693309261245303787291049957275390625

        System.out.println(bd1);
        System.out.println(bd2);

        //2.通过传递字符串表示的小数来创建对象
        BigDecimal bd3 = new BigDecimal("0.01");    //0.01
        BigDecimal bd4 = new BigDecimal("0.09");    //0.09

        System.out.println(bd3);
        System.out.println(bd4);

        //3.进行求和运算
        BigDecimal bd5 = bd3.add(bd4);
        System.out.println(bd5);                        //0.10

        //4.通过静态方法获取对象
        BigDecimal bd6 = BigDecimal.valueOf(10);
        System.out.println(bd6);                        //10

        //细节:
        //1.如果要表示的数字不大,没有超出double的取值范围,建议使用静态方法BigDecimal.valueOf()
        //2.如果要表示的数字比较大,超出了double的取值范围,建议使用构造方法
        //3.如果我们传递的是0~10之间的整数,那么方法会返回已经创建好的对象,不会重新new

        BigDecimal bd7 = BigDecimal.valueOf(10);
        System.out.println(bd6 == bd7);                 //true
        BigDecimal bd8 = BigDecimal.valueOf(10.0);
        System.out.println(bd6 == bd8);                 //false  如果传递double类型,一定会创建新的对象
        
    }
}

2.3 BigDecimal 中常见的成员方法

在这里插入图片描述

package BigNum;

import java.math.BigDecimal;
import java.math.RoundingMode;

public class BigDecimalDemo2 {
    public static void main(String[] args) {
        //1.加法
        BigDecimal bd1 = BigDecimal.valueOf(10.0);
        BigDecimal bd2 = BigDecimal.valueOf(2.0);
        BigDecimal bd3 = bd1.add(bd2);
        System.out.println(bd3);

        //2.减法
        BigDecimal bd4 = bd1.subtract(bd2);
        System.out.println(bd4);

        //3.乘法
        BigDecimal bd5 = bd1.multiply(bd2);
        System.out.println(bd5);

        //4.除法
        BigDecimal bd6 = bd1.divide(bd2);       //如果能除尽,可以用这行方法
        BigDecimal bd7 = bd1.divide(bd2, 2, RoundingMode.HALF_UP);      //如果除不尽,必须用这行方法

        //舍入模式
        //UP:向远离零的方向舍入
        //DOWN:向零的方向舍入
        //CEILING:向正无限大方向舍入
        //FLOOR:向负无限大方向舍入
        //HALF_UP:向最接近数字方向舍入(四舍五入)
        //HALF_DOWN:向最近数字方向舍入(四舍五舍)
        
    }
}

2.4 BigDecimal 的底层存储方式

        实际上 BigDecimal 在底层是一个数组,它是这样存储的:

BigDecimal bd = new BigDecimal("0.226");

        它会将"0.226"拆分成’0’,‘.’,‘2’,‘2’,‘6’,这五个字符,然后寻找他们对应的 ASC-II 码,存储在一个 byte 类型的数组中。

['0','.','2','2','6']
[48, 46, 50, 50, 54]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1994962.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

自动驾驶计算芯片企业“流血”上市,小米、腾讯等曾投7亿美元

"自动驾驶市场何时迎来爆发?" 作者 | 魏 强 编辑 | 卢旭成 今天,自动驾驶计算芯片企业Black Sesame International HoldingLimited(黑芝麻智能)在港交所上市,发行价28港元,募资总额10.36亿港元。 黑芝麻智能号称国…

牛客周赛 Round 54 (个人题解)(待补全)

前言: 如今已经回到返校回家,在家中的学习热情明显下降,在加上练车、和朋友亲戚聚一聚,学习的时间明显下降,希望自己能更加努力一点吧,之后想通过发博客来监督自己在暑假家中的努力,希望自己能做…

剖析算法内部结构----------贪心算法

什么是贪心算法? 贪心算法(Greedy Algorithm)是一种在问题求解过程中,每一步都采取当前状态下最优(即最有利)的选择,从而希望导致最终的全局最优解的算法策略。 贪心算法的核心思想是做选择时&…

Elasticsearch 查询规则现已正式发布 - query rules

作者:来自 Elastic Kathleen DeRusso 查询规则(query rules)允许使用细粒度、上下文特定的解决方案来更改特定查询或搜索用例的搜索结果。这对于需要将品牌或赞助结果固定在特定关键字的搜索结果列表顶部的广告系列很有帮助,但对于…

B2 双电机系列挂轨巡检机器人:解决巡检难题,提升工业效能

随着工业自动化的不断发展,传统的人工巡检方式已经难以满足现代工业对安全、效率和精度的要求。旗晟机器人推出的B2双电机系列挂轨巡检机器人,以其独特的优势,为工业巡检领域带来了革命性的变化。 一、产品亮点 B2双电机系列挂轨巡检机器人以…

数据结构初阶最终讲:排序

数据结构初阶最终讲:排序 1.排序的概念及其运用1.1什么是排序1.2排序的运用1.3常见排序算法 2.冒泡排序3.直接插入排序4.堆排序5.测试代码:排序性能对比5.1直接插入排序时间复杂度分析 6.希尔排序6.1希尔排序时间复杂度分析 7.选择排序7.1初步思路7.2选择…

【Python系列】异步编程在 Python 中的应用

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

WinCC7.5零基础教学:多功能VB/C脚本基础框架模板程序详解!报表、配方、面板类型、菜单栏切换画、IO控制模板一应俱全,0基础小白值得拥有!

了解基础框架完整功能请观看视频! 观看完整教学视频点击这里(腾讯视频可放心观看) 以下是wincc多功能脚本基础框架项目功能简介: 功能一:多功能标题窗口模块 模块主要功能包括实时报警窗口信息、人员登录登出、报警消…

24暑假算法刷题 | Day30 | 贪心算法 IV | 452. 用最少数量的箭引爆气球,435. 无重叠区间,763. 划分字母区间

目录 452. 用最少数量的箭引爆气球题目描述题解 435. 无重叠区间题目描述题解 763. 划分字母区间题目描述题解 452. 用最少数量的箭引爆气球 点此跳转题目链接 题目描述 有一些球形气球贴在一堵用 XY 平面表示的墙面上。墙面上的气球记录在整数数组 points ,其中…

印刷企业实施数字工厂管理系统后能提升哪些效益

在当今这个数字化转型浪潮席卷全球的时代,印刷企业作为传统制造业的重要组成部分,正面临着前所未有的挑战与机遇。为了提升生产效率、降低成本、增强市场竞争力,越来越多的印刷企业开始引入数字工厂管理系统,这一举措不仅重塑了企…

Inno Setup根据系统的不同(32位/64位)安装不同的exe

注意事项 Inno Setup6.0及以上版本生成的可执行文件,可以运行在Windows7及以上系统,不支持WindowsXP系统。 如果要运行在WindowsXP系统上,需要下载Inno Setup6.0之前的版本。 Inno Setup 汉化版5.3.4下载链接: https://download…

从入门到精通:大学生编程技能提升全攻略

文章目录 每日一句正能量前言编程语言选择编程语言选择:为新手导航Python:初学者的友好伙伴JavaScript:Web开发的核心Java:企业级应用的经典C:系统编程的基石Ruby:优雅高效的编程Swift:iOS开发的…

OBS设置大揭秘:参数优化技巧与顶级录屏软件全攻略

在这个数字化的时代,屏幕录制已成为我们记录和分享知识、技能的重要手段。如果你还在为寻找一款既专业又易用的录屏软件而烦恼,那么今天的文章将为你揭开谜底。 录屏软件一、OBS studio OBS studio,作为录屏和直播领域的标杆,其功…

echarts图例旁边加百分比及百分比对齐

一、效果图 在这里插入图片描述 二、代码 import cirle from /assets/imgs/dataScree/ybp.pnglet option{tooltip: {trigger: item,formatter: function (params) {return }},legend: {orient: vertical, // 图例列表的布局朝向,horizontal为水平,vertical为垂直…

电话机器人能提升销售效率

经济敏捷发展的当天,任何行业都不离开市场,无法让更多人理解本人企业本人的产物。那样的话,像电话营销那样抢手的行业也面临很大的困难,员工不仅工作压力大,工作时间长,呼叫量多,还能忍受顾客的…

LangChain: Reduce size of tokens being passed to OpenAI

题意:在使用 LangChain时,需要减少传递给OpenAI的令牌(tokens)的数量 问题背景: I am using LangChain to create embeddings and then ask a question to those embeddings like so: 我正在使用 LangChain 来创建嵌…

记录|To run this application, you must install .NET Core.【C#,VS】

目录 前言一、问题描述二、解决办法三、.NET版本和Windows版本对接更新时间 前言 参考文章: 1、安装失败,提示“To run this application,you must install .netcore…” 2、【bug】to run this application ,you must install .net 3、在 Windows 上安装…

【亲测管用】Windows11 部署Maxkb + 本地Ollama

一、下载地址 maxkb:https://maxkb.cn/ ollama: https://ollama.com/download/windows 二、安装ollama 2.1 默认安装 直接install就好,默认是安装到C盘里面的。 安装好之后会显示在 直接打开cmd黑窗口,输入命令即可查看。 2.2 ollama…

什么牌子的洗地机好用?石头、添可、希亦真实使用测评对比!

随着科技的不断进步,许多人已经更新了家中的清洁工具。在挑选时,大家可能会看到很多网络攻略,但看得越多,反而越难抉择。其实,最直接的方法是看看这些工具的真实使用体验,这样就能大概知道自己使用时的感受…

5G 网络切片

5G 业务分类 增强型移动宽带(eMBB) 传统数据业务,特点是高带宽超高可靠性低时延业务(URLLC)无人驾驶、工业自动化等业务, 特点是高可靠、低时延海量机器类通信(mMTC) 物联网,特点是大量连接,时延不敏感,数…