60从零开始学Java之与数字相关的类有哪些?

2023-09-21 08:36:59

作者:孙玉昌,昵称【一一哥】,另外【壹壹哥】也是我哦

千锋教育高级教研员、CSDN博客专家、万粉博主、阿里云专家博主、掘金优质作者

前言

我们在解决实际问题时,会经常对数字、日期和系统设置进行处理,比如在我们的代码中,经常会遇到一些数字&数学问题、随机数问题、日期问题和系统设置问题等。为了解决这些问题,Java给我们提供了多个处理相关问题的类,比如Number类、Math类、Random类、BigInteger类、BigDecimal类、Date类、System类等。接下来,壹哥会利用几篇文章,给大家详细地介绍这些与数学、日期、系统处理等相关的类,本篇文章我们先从Number数字类和Math数学类学起。

-----------------------------------------------前戏已做完,精彩即开始---------------------------------------------

全文大约【3000】字,不说废话,只讲可以让你学到技术、明白原理的纯干货!本文带有丰富的案例及配图视频,让你更好地理解和运用文中的技术概念,并可以给你带来具有足够启迪的思考......

配套开源项目资料

Github:

GitHub - SunLtd/LearnJava

Gitee:

从零开始学Java: 从零开始学Java系列稀土掘金专栏地址:https://juejin.cn/column/7175082165548351546CSDN专栏地址:https://yiyige.blog.csdn.net/article/details/129377219?spm=1001.2014.3001.5502

一. Number类

1. 内容回顾

在学习Java里的Math数学类之前,我们再来回顾一下之前学习过的Number数字类。

我们知道,Java里的数据类型可以分为引用类型和基本类型,其中基本类型有3大类8个子类,如下图所示:

实际上,无论是整数型还是浮点型,它们都是数值型,当我们定义数值型变量时,都是直接操作的数字。而在实际开发中,我们还经常遇到需要使用对象,而不是使用内置数据类型的情况。所以为了解决这个问题,Java又为每一个内置的基本数据类型提供了对应的包装类。其中,6个数值型对应的包装类(Byte、Short、Integer、Long、Float、Double),都是抽象类Number的子类。在基本类型和包装类型之间,会涉及到装箱和拆箱的操作,大家可以回顾一下这是怎么回事,如果你想不起来,请回过头来看看壹哥之前的文章哦。

2. 数字格式化

我们在使用数字时,很多时候并不只是简单地原文展示,还要对这些数字进行各种格式化操作,比如设置小数点后几位、数字后带%号或货币符号等。这种使用场景,在解决实际问题时是很普遍的。但我们不用在数字后手动添加,Java自带了一个DecimalFormat类,可以对数字进行格式化处理。
DecimalFormat是NumberFormat的子类,用于格式化十进制数字,该类包含一个模式和一组符号,这些常用的符号含义如下:

符号

说明

0

显示数字,如果位数不够则补0

#

显示数字,如果位数不够不发生变化

.

小数分隔符

-

减号

,

组分隔符

E

分隔科学记数法中的尾数和小数

%

前缀或后缀,乘以 100 后作为百分比显示

?

乘以 1000 后作为千进制货币符显示。用货币符号代替。如果双写,用国际货币符号代替。如果出现在一个模式中,用货币十进制分隔符代替十进制分隔符

接下来壹哥通过一个案例来演示DecimalFormat的用法:

/**
 * @author 一一哥Sun 
 * V我领资料:syc_2312119590 
 * 各平台都有壹哥的同名博客哦
 */
public class Demo08 {
	public static void main(String[] args) {
		// 实例化DecimalFormat类对象,并设置格式
		//小数点后保留1位
		DecimalFormat df1 = new DecimalFormat("0.0");
		//整数格式
		DecimalFormat df2 = new DecimalFormat("#.#");
		//小数点后保留3位小数
		DecimalFormat df3 = new DecimalFormat("000.000");
		//以100%百分比格式显示
		DecimalFormat df4 = new DecimalFormat("#%");
		
		float f = 1000f;
		// 对输入的数字应用格式,并输出结果
		System.out.println("0.0格式:" + df1.format(f));
		System.out.println("#.#格式:" + df2.format(f));
		System.out.println("000.000格式:" + df3.format(f));
		System.out.println("百分比格式:" + df4.format(f));
	}
}

二. Math数学类

1. 简介

在开发的时候,我们经常需要对数字进行各种数学计算,虽然Java给我们提供了+、-、*、/ 和 % 等基本算术运算符,但这些符号并不能进行更复杂的数学运算,例如三角函数、对数运算、指数运算等。所以为了方便实现这些数学计算功能,Java自身就给我们提供了一个Math数学类,用于进行各种常见的数学操作。

Math中提供了用于执行基本数学运算的多个属性和方法,如初等指数、对数、平方根和三角函数等。Math 类位于 java.lang包中,它的构造方法是 private私有的,因此我们无法创建 Math类对象。为了方便调用这些方法和属性,Math类中的很多方法和属性都被定义为static形式,这样我们就可以直接调用了。

接下来壹哥就给大家分别介绍一下Math类中的常用属性和方法,这些方法比较多,大家不用专门的记忆,以后用到时根据名字就能猜出来它们的功能。但是对于一些容易引起混淆的方法,壹哥还是希望大家要稍微记一下。

2. 静态常量

Math类给我们提供了两个比较常用的静态常量,分别是 E 和 PI,它们的值分别等于 e(自然对数) 和 π(圆周率)。这两个属性我们可以直接调用,如下所示:

public static void main(String[] args) {
	//静态常量E和PI
	System.out.println("E常量的值:" + Math.E);
	System.out.println("PI常量的值:" + Math.PI);
}

3. 计算最大值、最小值和绝对值

我们还经常对数字计算最大值、最小值和绝对值,Math类中提供了对应的多个重载方法,这些方法如下表所示:

方法

说明

static int abs(int a)

返回 a 的绝对值

static int max(int x,int y)

返回 x 和 y 中的最大值

static int min(int x,int y)

返回 x 和 y 中的最小值

以上这4个方法,分别都有4个重载方法,主要是方法的参数类型不同,而且返回值也不同,它们都可以接收int、long、float、double 4种类型的参数。这几个方法的用法如下:

public static void main(String[] args) {
	//计算最大值、最小值、绝对值
	System.out.println("5和35中的最大值:" + Math.max(35, 5));
    System.out.println("0.1和-100中的较小值:" + Math.min(0.1, -100));
    System.out.println("-900的绝对值:" + Math.abs(-900));
}

4. 求整运算

Math类给我们提供了好几个用于求整的方法,用于得到整数部分,如下表所示:

方法

说明

static double ceil(double a)

返回大于或等于 a 的最小整数

static double floor(double a)

返回小于或等于 a 的最大整数

static double rint(double a)

返回最接近 a 的整数值,如果有两个同样接近的整数,则结果取偶数

static int round(float a)

将参数加上 1/2 后返回与参数最近的整数

static long round(double a)

将参数加上 1/2 后返回与参数最近的整数,然后强制转换为长整型

以上方法的用法如下所示:

import java.util.Scanner;

/**
 * @author 一一哥Sun
 */
public class Demo03 {

	public static void main(String[] args) {
		//求整运算
		Scanner input = new Scanner(System.in);
        System.out.println("请输入一个数字...");
        //num=10.5
        double num = input.nextDouble();
		
		//向上取整
        System.out.println("向上取整:"+Math.ceil(num));//11.0
        
        //向下取整
        System.out.println("向下取整:"+Math.floor(num));//10.0
        
        //四舍五入
        System.out.println("四舍五入:"+Math.round(num));//11
        
        //返回最接近num的整数值,如果有两个同样接近的整数,则结果取偶数.
        System.out.println("最接近 "+num+" 的整数:" + Math.rint(num));//10.0
	}

}

5. 三角函数运算

Math中还给我们提供了用于计算三角函数的方法,如下表所示:

方法

说明

static double sin(double a)

返回角的三角正弦值,参数以孤度为单位

static double cos(double a)

返回角的三角余弦值,参数以孤度为单位

static double asin(double a)

返回一个值的反正弦值,参数域在 [-1,1],值域在 [-PI/2,PI/2]

static double acos(double a)

返回一个值的反余弦值,参数域在 [-1,1],值域在 [0.0,PI]

static double tan(double a)

返回角的三角正切值,参数以弧度为单位

static double atan(double a)

返回一个值的反正切值,值域在 [-PI/2,PI/2]

static double toDegrees(double angrad)

将用孤度表示的角转换为近似相等的用角度表示的角

staticdouble toRadians(double angdeg)

将用角度表示的角转换为近似相等的用弧度表示的角

以上方法的用法如下所示:

/**
 * @author 一一哥Sun
 */
public class Demo04 {
	public static void main(String[] args) {
		//三角函数运算
		//Math.sin()方法参数的单位是弧度,90度表示的是角度,需要把90度转换为弧度,即Math.PI/180*90,故转换后的弧度为Math.PI/2
		System.out.println("90度的正弦值:" + Math.sin(Math.PI/2));
        System.out.println("0度的余弦值:" + Math.cos(0));
        System.out.println("30的正切值:" + Math.tan(30));
        System.out.println("30的反正切值:" + Math.atan(30));
        System.out.println("1.8弧度的角度值:" + Math.toDegrees(1.8));
        System.out.println("100度的弧度值:" + Math.toRadians(100.0));
	}
}

6. 指数运算

指数运算包括求方根、取对数、求n次方等运算,Math类中定义的指数运算方法如下表所示:

方法

说明

static double exp(double a)

返回 e 的 a 次幂

static double pow(double a,double b)

返回以 a 为底数,以 b 为指数的幂值

static double sqrt(double a)

返回 a 的平方根

static double cbrt(double a)

返回 a 的立方根

static double log(double a)

返回 a 的自然对数,即 lna 的值

static double log10(double a)

返回以 10 为底 a 的对数

以上方法的用法如下所示:

public static void main(String[] args) {
	//指数运算
	System.out.println("5的立方值:" + Math.pow(5, 3));
    //求a的立方根,参数是要开立方的数
    System.out.println("27的立方根:"+Math.cbrt(27));
	System.out.println("16的平方根:" + Math.sqrt(16));
    System.out.println("10为底,2的对数:" + Math.log10(2));
}

7. 生成随机数

在Math类中还给我们提供了一个用于生成[0~1)范围内随机数的random()方法。该方法没有参数,它默认会返回一个 >=0.0、<1.0 的 double类型随机数,即随机数的取值范围是[0~1)。我们只需对 random()方法的返回值稍加处理,即可产生任意范围内的随机数。该方法使用比较简单,案例如下:

//随机数 默认的范围[0,1)
System.out.println(Math.random());

//随机生成一个两位数,[0,1)*90,0,90) + 10     
System.out.println((int)(Math.random()*90)+10);

8. 配套视频

与本节内容配套的视频链接如下:

External Player - 哔哩哔哩嵌入式外链播放器

------------------------------------------------正片已结束,来根事后烟----------------------------------------------

三. 结语

至此,壹哥就把与数字、数学、随机数等相关的类给大家介绍完了,本节内容没有特别难的地方,主要是需要大家记住几个常用方法即可。如果你独自学习觉得有很多困难,可以加入壹哥的学习互助群,大家一起交流学习。

更多推荐

Linux知识

文章目录一、Apt1、查看操作系统信息2、换源3、比较4、用法5、ubuntu获取源码pkg-config一、Apt1、查看操作系统信息使用以下命令查看本机的操作系统和位数信息:uname-m&&cat/etc/*release输出:x86_64DISTRIB_ID=UbuntuDISTRIB_RELEASE=16.0

Pytest系列-使用自定义标记mark(6)

简介pytest可以支持自定义标记,自定义标记可以把一个web项目划分为多个模块,然后指定模块名称执行Pytest里面自定义标记用法:将@pytest.mark.标记名称放到测试函数或者类上面使用:执行时加上-m标记名进行用例筛选,例如加上-mapp,就执行标记名为app的用例。如果不运行app相关的用例,则加上-m“

面试中的冲突解决:展示你的调解能力

🌷🍁博主猫头虎(🐅🐾)带您GotoNewWorld✨🍁🦄博客首页——🐅🐾猫头虎的博客🎐🐳《面试题大全专栏》🦕文章图文并茂🦖生动形象🐅简单易学!欢迎大家来踩踩~🌺🌊《IDEA开发秘籍专栏》🐾学会IDEA常用操作,工作效率翻倍~💐🌊《100天精通Golang(基础入门篇)》🐅学会Gol

【Linux基础】第28讲 Linux Vi编辑器

在Linux下一班使用Vi编辑器来编辑文件vi既可以查看文件也可以编辑文件而vim是vi的升级版本,具备更多的功能。vi如果目标文件不存在,会创建新的文件。但如果新文件没做编辑,退出后还会消失。VI的三种模式介绍三种模式(状态):编辑、底行、命令模式。切换到编辑模式:按i、o、a键;切换到底行模式:按:冒号;切换到命令

【深度学习】 Python 和 NumPy 系列教程(廿五):Matplotlib详解:3、多子图和布局:subplot()函数

目录一、前言二、实验环境三、Matplotlib详解1、2d绘图类型2、3d绘图类型3、多子图和布局1.subplot()函数简单示例一、前言Python是一种高级编程语言,由GuidovanRossum于1991年创建。它以简洁、易读的语法而闻名,并且具有强大的功能和广泛的应用领域。Python具有丰富的标准库和第三

Python 10之异常模块包

😀前言在Python编程中,我们时常会遇到各种异常和错误,同时我们也会使用多个模块和包来组织和结构化我们的代码。理解如何有效地处理异常和组织我们的代码是成为一个成功的Python程序员的关键。.在本教程中,我们将深入探讨Python中的异常处理,从基本的异常捕获到更高级的异常处理技术,如指定错误类型和创建自定义异常。

【送书活动】大模型赛道如何实现华丽的弯道超车

文章目录导读模型训练01具备对海量小文件的频繁数据访问的I/O效率02提高GPU利用率,降低成本并提高投资回报率03支持各种存储系统的原生接口04支持单云、混合云和多云部署Alluxio01通过数据抽象化统一数据孤岛02通过分布式缓存实现数据本地性03优化整个工作流的数据共享04通过并行执行数据预加载、缓存和训练来编排

Matlab-resample

1.resample步骤1:低通滤波首先,resample函数会应用一个低通滤波器,以滤除输入信号中高于重采样频率的频率成分。这是为了防止混叠现象,即重采样后出现在新采样率频带之外的频率成分。在MATLAB中,默认使用一个FIR滤波器进行低通滤波,滤波器的设计根据重采样因子和滤波器长度来确定。此外,还要补偿由于滤波带的

Node.js

它们都是基于nodejs开发的WebpackViteBabelVSCodeFigmaPostman常用的命令行指令C:/D:切换盘符dir列出当前目录下的所有文件cd目录名进入到指定目录md目录名创建一个文件夹rd目录名删除一个文件夹.表示当前目录..表示上一级目录当我们在命令行窗口打开一个文件,或调用一个程序时,系统

JWT安全

文章目录JWT是什么?为什么要使用JWT?JWT的数据结构JWT的工作过程JWT是什么?JSONWebToken(JWT)是一个开放标准(RFC7519),它定义了一种紧凑的、自包含的方式,用于作为JSON对象在各方之间安全地传输信息。JWT全称JSONWebToken,是一种传输信息的标准,用于JSON对象在各方之间

代码随想录算法训练营第58天 | ● 739. 每日温度 ● 496.下一个更大元素 I

文章目录前言一、739.每日温度二、496.下一个更大元素I总结前言单调栈;一、739.每日温度单调栈的本质是空间换时间,因为在遍历的过程中需要用一个栈来记录右边第一个比当前元素高的元素,优点是整个数组只需要遍历一次。更直白来说,就是用一个栈来记录我们遍历过的元素,因为我们遍历数组的时候,我们不知道之前都遍历了哪些元素

热文推荐