java8 Math新增方法介绍

通常都认为java8新功能主要包括函数式编程及lambda表达式。然而,除了那些大的特点之外,还有其他的,影响力小却很有趣,大多时候不为人所知,甚至不太被人评论。

本文我们列举java.lang.Math类中新增的方法,并给一些小的示例来说明。

*exact() 方法

首先看一组扩展已经存在的常用算术操作方法,从名称及可以知其意,处理实现原有功能外,还增加了当结果溢出时抛出异常。这些方法可以使用integer和long类型作为参数。

addExact()

返回两个参数之和,结果溢出时抛出ArithmeticException 异常:

Math.addExact(100, 50); // returns 150

Math.addExact(Integer.MAX_VALUE, 1); // throws ArithmeticException

substractExact()方法

返回两个参数之差,结果溢出时抛出ArithmeticException 异常:

Math.subtractExact(100, 50); // returns 50

Math.subtractExact(Long.MIN_VALUE, 1); // throws ArithmeticException

incrementExact()方法

返回参数值加一,结果溢出时抛出ArithmeticException 异常:

Math.incrementExact(100); // returns 101

Math.incrementExact(Integer.MAX_VALUE); // throws ArithmeticException

decrementExact()方法

返回参数值减一,结果溢出时抛出ArithmeticException 异常:

Math.decrementExact(100); // returns 99

Math.decrementExact(Long.MIN_VALUE); // throws ArithmeticException

multiplyExact()方法

返回两个参数之积,结果溢出时抛出ArithmeticException 异常:

Math.multiplyExact(100, 5); // returns 500

Math.multiplyExact(Long.MAX_VALUE, 2); // throws ArithmeticException

negateExact()方法

改变参数符号,结果溢出时抛出ArithmeticException 异常。我们来看看值在内存中的表示,并理解为什么会溢出,因为并不像其他exact方法那么直观看出来:

Math.negateExact(100); // returns -100

Math.negateExact(Integer.MIN_VALUE); // throws ArithmeticException

第二个示例需要解释下,因为不能一眼看出来:溢出是因为Integer.MIN_VALUE 是 −2.147.483.648,而Integer.MAX_VALUE 是 2.147.483.647,所以返回值超出整数范围。

其他方法

floorDiv()

第一个参数除以第二参数,然后针对结果执行floor操作,返回小于或等于商的整数:

Math.floorDiv(7, 2)); // returns 3

商为 3.5 ,所以 floor(3.5) == 3.

让我们看另一个示例:

Math.floorDiv(-7, 2)); // returns -4

商为-3.5 ,所以 floor(-3.5) == -4.

modDiv()方法

该方法与前面floorDiv()方法类似, 但在模数或余数上应用floor() 操作,而不是商:

Math.modDiv(5, 3)); // returns 2

我们看到 , modDiv() 方法两个参数为正数,和 % 操作符效果一样。让看看另一个不同示例:

Math.modDiv(-5, 3)); // returns 1

结果为 1 而不是 2 ,因为floorDiv(-5, 3) 是 -2 ,而不是 -1.

nextDown()方法

返回参数直接较低的值(支持 float 或 double 参数):

float f = Math.nextDown(3); // returns 2.9999998

double d = Math.nextDown(3); // returns 2.999999761581421

总结

我们描述了java8中java.lang.Math类中所有新的方法,并通过示例给与解释说明。

补充知识:math类常用方法详细总结

说明:Math 类位于 java.lang 包中,主要提供了一些常用的数学函数和计算

备注:一些在工程计算中才用的方法此处不做介绍

一、取整运算

1、Math.ceil(double x)

释义:向上取整,返回大于该值的最近 double 值

System.out.println(Math.ceil(1.23)); // 2.0

System.out.println(Math.ceil(-1.23)); // -1.0

2、Math.floor(double x)

释义:向下取整,返回小于该值的最近 double 值

System.out.println(Math.floor(1.23)); // 1.0

System.out.println(Math.floor(-1.23)); // -2.0

3、Math.round(double x)

释义:四舍五入取整,参数类型:double、float

System.out.println(Math.round(1.43)); // 1
System.out.println(Math.round(1.53)); // 2
System.out.println(Math.round(-1.43)); // -1
System.out.println(Math.round(-1.53)); // -2

二、随机运算

Math.random()

释义:内部调用了 Random.nextDouble() 方法,生成一个伪均匀分布在 [0,1)之间的 double 值

System.out.println((int)(Math.random() * 10 + 1)); // 生成范围再[1, 11)之间的伪随机数

三、符号运算

1、Math.abs(int x)

释义:计算绝对值,参数类型:int、long、float、double

System.out.println(Math.abs(-1)); // 1

2、Math.negateExact(int x)

释义:计算相反值,参数类型:int、long

System.out.println(Math.negateExact(-1)); // 1

四、大小运算

1、Math.max(int x, int y)

释义:获取两个参数中的最大值,参数类型:int、long、float、double

System.out.println(Math.max(1, 2)); // 2

2、Math.min(int x, int y)

释义:获取两个参数中的最小值,参数类型:int、long、float、double

System.out.println(Math.min(1, 2)); // 1

3、Math.rint(double x)

释义:获取与参数最接近的double值

System.out.println(Math.rint(1.4)); // 1.0
System.out.println(Math.rint(1.5)); // 2.0
System.out.println(Math.rint(-1.4)); // -1.0
System.out.println(Math.rint(-1.5)); // -2.0

以上这篇java8 Math新增方法介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • java8新特性 stream流的方式遍历集合和数组操作

    前言: 在没有接触java8的时候,我们遍历一个集合都是用循环的方式,从第一条数据遍历到最后一条数据,现在思考一个问题,为什么要使用循环,因为要进行遍历,但是遍历不是唯一的方式,遍历是指每一个元素逐一进行处理(目的),而并不是从第一个到最后一个顺次处理的循环,前者是目的,后者是方式. 所以为了让遍历的方式更加优雅,出现了流(stream)! 1.流的目的在于强掉做什么 假设一个案例:将集合A根据条件1过滤为子集B,然后根据条件2过滤为子集C 在没有引入流之前我们的做法可能为: public cl

  • Java8 Stream对两个 List 遍历匹配数据的优化处理操作

    使用场景,有两个List<Map<String,Object>>集合,第一个集合的所有元素都是需要保留的. 第一个集合的值为: {name=张三丰1, id=1} {name=张三丰2, id=2} {name=张三丰3, id=3} {name=张三丰4, id=4} {name=张三丰5, id=5} {name=张三丰6, id=6} {name=张三丰7, id=7} {name=张三丰8, id=8} 第二个集合的值为: {grade=61, id=1} {grade=6

  • java8从list集合中取出某一属性的值的集合案例

    我就废话不多说了,大家还是直接看代码吧~ List<Order> list = new ArrayList<User>(); Order o1 = new Order("1","MCS-2019-1123"); list.add(o1 ); Order o2= new Order("2","MCS-2019-1124"); list.add(o2); Order o3= new Order("

  • java8 Math新增方法介绍

    通常都认为java8新功能主要包括函数式编程及lambda表达式.然而,除了那些大的特点之外,还有其他的,影响力小却很有趣,大多时候不为人所知,甚至不太被人评论. 本文我们列举java.lang.Math类中新增的方法,并给一些小的示例来说明. *exact() 方法 首先看一组扩展已经存在的常用算术操作方法,从名称及可以知其意,处理实现原有功能外,还增加了当结果溢出时抛出异常.这些方法可以使用integer和long类型作为参数. addExact() 返回两个参数之和,结果溢出时抛出Arit

  • ES6新增的math,Number方法

    ES6新增的math,Number方法,下面总结了一些我觉得有用的 Nunber.isInteger()判断是否为整数,需要注意的是1,和1.0都会被认为是整数 console.log(Number.isInteger(1.0))//true console.log(Number.isInteger(1))//true console.log(Number.isInteger("1"))//false console.log(Number.isInteger("1.1&quo

  • python math模块使用方法介绍

    math常用方法 1.math.ceil()向上取整 import math print(math.ceil(56.1)) 57 2.math.floor()向下取整 import math print(math.floor(56.1)) 56 3.math.fabs()取绝对值 import math print(math.fabs(56)) print(math.fabs(-56)) 56.056.0 4.math.fmod()求模运算 import math print(math.fmod

  • JavaScript Math.round() 方法

     Math.round()方法的定义和用法: Math.round()方法将对参数进行四舍五入操作. 点击可参阅更多相关Math对象方法和属性. 语法结构: Math.round(x) 参数列表: 参数 描述 x 必需.必须是数值类型. 实例代码: 实例一: 复制代码 代码如下: console.log(Math.round(-2.1)); 输出结果:-2. 实例二: 复制代码 代码如下: console.log(Math.round(-2.9)); 输出结果:-3. 实例三: 复制代码 代码如

  • javascript的几种继承方法介绍

    1.原型链继承:构造函数.原型和实例的关系:每个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针.确认原型和实例之间的关系用instanceof. 原型链继承缺点:字面量重写原型会中断关系,使用引用类型的原型,并且子类型还无法给超类型传递参数 function Parent(){ this.name='mike'; } function Child(){ this.age=12; } //儿子继承父亲(原型链) Child.prototype

  • JdbcTemplate方法介绍与增删改查操作实现

    JdbcTemplate介绍 为了使 JDBC 更加易于使用,Spring 在 JDBCAPI 上定义了一个抽象层, 以此建立一个JDBC存取框架,Spring Boot Spring Data-JPA. 作为 SpringJDBC 框架的核心, JDBC 模板的设计目的是为不同类型的JDBC操作提供模板方法. 每个模板方法都能控制整个过程,并允许覆盖过程中的特定任务. 通过这种方式,可以在尽可能保留灵活性的情况下,将数据库存取的工作量降到最低. JdbcTemplate方法介绍 JdbcTem

  • 浅析Java 9 Optional API 新增方法

    本文介绍Java 9 Optional API 新增方法.除了模块化,Java 9 也给Optional类增加了三个方法. 1. or 方法 有时当Optional为空时,我们想执行一些其他逻辑并也返回Optional.在Java9之前Optional类仅有orElse()和orElseGet()方法,但两者都返回非包装值. Java9引入or()方法当Optional为空时返回另一个Optional.如果Optional有定义值,则传入or方法的lambda不被执行: @Test public

  • Java8 Comparator排序方法实例详解

    这篇文章主要介绍了Java8 Comparator排序方法实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Java8 中 Comparator 接口提供了一些静态方法,可以方便于我们进行排序操作,下面通过例子讲解下如何使用 对整数列表排序(升序) List<Integer> list = Arrays.asList(1, 4, 2, 6, 2, 8); list.sort(Comparator.naturalOrder()); Sys

  • 细品Java8中hashCode方法的使用

    简介 散列函数(英语:Hash function)又称散列算法.哈希函数,是一种从任何一种数据中创建小的数字"指纹"的方法.散列函数把消息或数据压缩成摘要,使得数据量变小,将数据的格式固定下来. Java语言对hashCode的应用 主要用途 hashcode是Object中的函数,所有类都拥有的一个函数,主要返回每个对象的hash值,主要用于哈希表中,如HashMap.HashTable.HashSet. 在这里需要注意的是,他就是为了在一些对象数组里面存储的时候可以节省空间.(我在

  • thinkphp5redis缓存新增方法实例讲解

    找到该文件 thinkphp/library/think/cache/driver/Redis.php 进行新增方法 在这里 我就举例几个 如何添加 添加的方法查看 redis教程 /** * 返回列表中指定区间内的元素 * */ public function lrange($key,$start,$end){ return $this->handler->lrange($key,$start,$end); } /** * 在list左边新增元素 * */ public function l

随机推荐