java mod函数的使用方法_java 数学计算的具体使用

3bc90872e8674a2e0008cb10987b3c9f.png

java.lang.Math 库提供了常用的数学计算工具

常量

final double E = 2.7182818284590452354; // 自然对数底数

final double PI = 3.14159265358979323846; // 圆周率

final double DEGREES_TO_RADIANS = 0.017453292519943295; // 角度转弧度

final double RADIANS_TO_DEGREES = 57.29577951308232; // 弧度转角度

取整

abs(x): 绝对值

floor(x): 向下取整

ceil(x): 向上取整

round(x): 四舍五入,如果有两个(x.5),返回较大的那个数

rint(x): 最接近的整数,如果有两个(x.5),返回偶数

floorDiv(x, y): 向下取整除法

floorMod(x, y): java 默认的取摸 % 得到的结果和 x 的符号相同,floorMod 和 y 的符号相同

double delta = 0.0000001;

assertEquals(Math.abs(-6), 6);

assertEquals(Math.floor(-6.2), -7, delta); // 向下取整

assertEquals(Math.floor(6.2), 6, delta);

assertEquals(Math.floor(6.8), 6, delta);

assertEquals(Math.ceil(-6.2), -6, delta); // 向上取整

assertEquals(Math.ceil(6.2), 7, delta);

assertEquals(Math.ceil(6.8), 7, delta);

assertEquals(Math.round(-6.2), -6, delta); // 四舍五入

assertEquals(Math.round(6.2), 6, delta);

assertEquals(Math.round(6.8), 7, delta);

assertEquals(Math.round(-6.5), -6, delta);

assertEquals(Math.round(6.5), 7, delta);

assertEquals(Math.rint(-6.2), -6, delta); // 最接近整数,如果存在两个,返回偶数

assertEquals(Math.rint(6.2), 6, delta);

assertEquals(Math.rint(6.8), 7, delta);

assertEquals(Math.rint(-6.5), -6, delta);

assertEquals(Math.rint(6.5), 6, delta);

assertEquals(Math.floorDiv(7, 3), 2);

assertEquals(Math.floorDiv(-7, 3), -3);

assertEquals(Math.floorMod(7, 3), 1);

assertEquals(Math.floorMod(-7, -3), -1);

assertEquals(Math.floorMod(-7, 3), 2);

assertEquals(-7 % -3, -1);

assertEquals(-7 % 3, -1);

三角函数

assertEquals(Math.sin(Math.PI / 2), 1.0, delta);

assertEquals(Math.cos(Math.PI), -1, delta);

assertEquals(Math.tan(Math.PI / 4), 1.0, delta);

assertEquals(Math.asin(1), Math.PI / 2, delta);

assertEquals(Math.acos(-1), Math.PI, delta);

assertEquals(Math.atan(1), Math.PI / 4, delta);

指数对数

pow(x, y): x^y,x 的 y 次方

sqrt(x): √x,x 的平方根

cbrt(x): 三次方根

hypot(x, y): √(x² + y²)

exp(x): e ^ x

expm1(x): e ^ x - 1

log(x): ln(x)

log10: lg(x)

log1p(x): ln(1+x)

assertEquals(Math.pow(3, 2), 9, delta);

assertEquals(Math.pow(2, 3), 8, delta);

assertEquals(Math.sqrt(4), 2, delta);

assertEquals(Math.cbrt(27), 3, delta);

assertEquals(Math.hypot(3, 4), 5, delta); // √(x² + y²)

assertEquals(Math.exp(2.5), Math.pow(Math.E, 2.5), delta); // e ^ x

assertEquals(Math.expm1(2), Math.exp(2) - 1, delta); // e ^ x - 1

assertEquals(Math.log(Math.exp(1.5)), 1.5, delta); // ln(x)

assertEquals(Math.log10(1000), 3, delta); // lg(x)

assertEquals(Math.log1p(Math.E - 1), 1, delta); // ln(1 + x)

双曲函数

sinh(x): (e ^ x - e ^ -x) / 2

cosh(x): (e ^ x + e ^ -x) / 2

tanh(x): sinh(x) / cosh(x)

assertEquals(Math.sinh(2), (Math.exp(2) - Math.exp(-2)) / 2, delta); // sinh(x) = (e ^ x - e ^ -x) / 2

assertEquals(Math.cosh(2), (Math.exp(2) + Math.exp(-2)) / 2, delta); // cosh(x) = (e ^ x + e ^ -x) / 2

assertEquals(Math.tanh(2), Math.sinh(2) / Math.cosh(2), delta); // tanh(x) = sinh(x) / cosh(x)

精确计算

普通的数值计算在溢出时是没有感知的,比如 Long.MAX_VALUE + 1 将得到结果 Long.MIN_VALUE,为了解决这种不合理,Math 提供了一些辅助函数,在结果溢出时将抛出异常

addExact(x, y): 加法

multiplyExact(x, y): 乘法

decrementExact(x, y): 递减

incrementExact(x, y): 递增

negateExact(x, y): 相反数

multiplyFull(x, y): 接受两个 int 返回一个 long,防止溢出

multiplyHigh(x, y): 返回两个 long 乘积的高 64 位

assertEquals(Long.MAX_VALUE + 1, Long.MIN_VALUE); // 溢出

assertThrows(ArithmeticException.class, () -> Math.addExact(Long.MAX_VALUE, 1)); // 加法溢出抛异常

assertThrows(ArithmeticException.class, () -> Math.multiplyExact(Long.MAX_VALUE, 2)); // 乘法

assertThrows(ArithmeticException.class, () -> Math.decrementExact(Long.MIN_VALUE)); // 递减

assertThrows(ArithmeticException.class, () -> Math.incrementExact(Long.MAX_VALUE)); // 递增

assertThrows(ArithmeticException.class, () -> Math.negateExact(Long.MIN_VALUE)); // 相反数

assertEquals(Math.addExact(1, 2), 3);

assertEquals(Math.multiplyExact(2, 3), 6);

assertEquals(Math.incrementExact(6), 7);

assertEquals(Math.decrementExact(6), 5);

assertEquals(Math.negateExact(-6), 6);

assertEquals(Math.multiplyFull(1, 2), 2); // 接受两个 int 返回一个 long,防止溢出

assertEquals(Math.multiplyHigh(1, 2), 0); // 返回两个 long 乘积的高 64 位

浮点数

任意两个浮点数之间都有无数个浮点数,因此大部分浮点数是无法表示的,只能选取一个最接近的,java 提供了一些接口来获取能表示的浮点数

System.out.println(Math.nextUp(1.1)); // 下一个浮点数

System.out.println(Math.nextDown(1.1)); // 上一个浮点数

System.out.println(Math.nextAfter(1.1, Double.POSITIVE_INFINITY)); // 下一个浮点数

System.out.println(Math.nextAfter(1.1, Double.NEGATIVE_INFINITY)); // 上一个浮点数

随机数

math 库随机数

System.out.println(Math.random()); // 0 ~ 1 之间的随机数

java.lang.Random

Random 类提供了更丰富的随机方法,可以返回各种不同类型的随机数

Random r = new Random();

System.out.println(r.nextInt());

System.out.println(r.nextLong());

System.out.println(r.nextFloat());

System.out.println(r.nextDouble());

Random 还提供了流式 api

Random r = new Random();

List li = r.ints().limit(10).boxed().map((x) -> Math.abs(x % 100)).collect(Collectors.toList());

System.out.println(li);

java.util.Random 是线程安全的,但是,跨线程的同时使用 java.util.Random 实例可能会遇到争用,从而导致性能下降。在多线程设计中考虑使用java.util.concurrent.ThreadLocalRandom 代替 java.util.Random,ThreadLocalRandom 和 Random 拥有一致的接口

链接

Math 测试代码: https://github.com/hatlonely/hellojava/blob/master/src/test/java/util/MathTest.java

随机数测试代码: https://github.com/hatlonely/hellojava/blob/master/src/test/java/util/RandomTest.java

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持云海天教程。

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

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

相关文章

java的debug模式_java第六章:debug模式介绍及大量实例练习

1.Debug模式1.1什么是Debug模式【理解】是供程序员使用的程序调试工具,它可以用于查看程序的执行流程,也可以用于追踪程序执行过程来调试程序。1.2Debug模式操作流程【应用】如何加断点选择要设置断点的代码行,在行号的区域后面单击鼠标左键即…

注解RequestMapping中的URI路径最前面到底需不需要加斜线?

注解RequestMapping中的URI路径最前面到底需不需要加斜线? 您有没有这样的困惑:在协同开发过程中,使用RequestMapping,或者是GetMapping,或者是PostMapping这类注解时,有的程序员加了斜线,有的程序员没有…

java ajax jquery分页插件_jquery ajax分页插件的简单实现

说到基于jQuery的ajax分页插件,那我们就先看看主要的代码结构:1、首先定义一个pager对象:var sjPager window.sjPager {opts: {//默认属性pageSize: 10,preText: "pre",nextText: "next",firstText: "First"…

java thrift连接池_由浅入深了解Thrift之客户端连接池化

一、问题描述在上一篇《由浅入深了解Thrift之服务模型和序列化机制》文章中,我们已经了解了thrift的基本架构和网络服务模型的优缺点。如今的互联网圈中,RPC服务化的思想如火如荼。我们又该如何将thrift服务化应用到我们的项目中哪?实现thrif…

Vue 进阶组件实战应用 -- 父子组件传值的应用实例(子父组件传值的两种触发方式)

基础的子组件和父组件通信已经搞定了,可以看此博客 父子组件传值基础应用 需求 现在需求是在一个父页面引用子组件,不只是要实现基本的父子组件传值。并且子组件给父组件传值的触发条件要在父页面触发。 目前小编采用的方式是使用ref 属性this.emit 方法…

学习Spring Boot:(一)入门

微服务 微服务其实是服务化思路的一种最佳实践方向,遵循SOA(面向服务的架构)的思路,各个企业在服务化治理上面的道路已经走得很远了,整个软件交付链上各个环节的基础设施逐渐成熟了,微服务就诞生了。 微服务…

学习Spring Boot:(二)启动原理

前言 主要了解前面的程序入口 SpringBootApplication 这个注解的结构。 正文 参考《SpringBoot揭秘 快速构建微服务体系》第三章的学习,总结下。 SpringBootApplication背后的秘密 Target(ElementType.TYPE) Retention(RetentionPolicy.RUNTIME) Documented In…

学习Spring Boot:(四)应用日志

前言 应用日志是一个系统非常重要的一部分,后来不管是开发还是线上,日志都起到至关重要的作用。这次使用的是 Logback 日志框架。 正文 Spring Boot在所有内部日志中使用Commons Logging,但是默认配置也提供了对常用日志的支持&#xff0c…

学习Spring Boot:(五)使用 devtools热部署

前言 spring-boot-devtools 是一个为开发者服务的一个模块,其中最重要的功能就是自动应用代码更改到最新的App上面去。原理是在发现代码有更改之后,重新启动应用,但是比速度比手动停止后再启动还要更快,更快指的不是节省出来的手工…

学习Spring Boot:(六) 集成Swagger2

前言 Swagger是用来描述和文档化RESTful API的一个项目。Swagger Spec是一套规范,定义了该如何去描述一个RESTful API。类似的项目还有RAML、API Blueprint。 根据Swagger Spec来描述RESTful API的文件称之为Swagger specification file,它使用JSON来表…

java的队列实现方法_Java实现队列的三种方法集合

数组实现队列//数组实现队列class queue{int[] a new int[5];int i 0;//入队操作public void in(int m) {a[i] m;}// 出队列操作 取出最前面的值 通过循环遍历把所有的数据向前一位public int out() {int index 0;int temp a[0];for(int j 0;j < i;j) {a[j] a[j 1];…

php 简转繁体,php如何实现简体繁体转换

思路&#xff1a;根据中文简体、繁体对应的数据表&#xff0c;将其整理成一个以简体字为键&#xff0c;繁体字为值的一个一维数组&#xff0c;类似下面这样的一个数组结构&#xff1a;$dataarray(侧>側,厂>廠);在线学习视频分享&#xff1a;php视频教程好了&#xff0c;根…

学习Spring Boot:(八)Mybatis使用分页插件PageHelper

首先Mybqtis可以通过SQL 的方式实现分页很简单&#xff0c;只要在查询SQL 后面加上limit #{currIndex} , #{pageSize}就可以了。 本文主要介绍使用拦截器的方式实现分页。 实现原理 拦截器实现了拦截所有查询需要分页的方法&#xff0c;并且利用获取到的分页相关参数统一在s…

学习Spring Boot:(九)统一异常处理

前言 开发的时候&#xff0c;每个controller的接口都需要进行捕捉异常的处理&#xff0c;以前有的是用切面做的&#xff0c;但是SpringMVC中就自带了ControllerAdvice &#xff0c;用来定义统一异常处理类&#xff0c;在 SpringBoot 中额外增加了 RestControllerAdvice。 使用…

php7 ast,PHP7 的抽象语法树(AST)带来的变化

什么是抽象语法树&#xff1f;抽象语法树(abstract syntax tree&#xff0c;AST)是源代码的抽象语法结构的树状表示&#xff0c;树上的每个节点都表示源代码中的一种结构&#xff0c;这所以说是抽象的&#xff0c;是因为抽象语法树并不会表示出真实语法出现的每一个细节&#x…

学习Spring Boot:(十)使用hibernate validation完成数据后端校验

前言 后台数据的校验也是开发中比较注重的一点&#xff0c;用来校验数据的正确性&#xff0c;以免一些非法的数据破坏系统&#xff0c;或者进入数据库&#xff0c;造成数据污染&#xff0c;由于数据检验可能应用到很多层面&#xff0c;所以系统对数据校验要求比较严格且追求可…

php 仿高德,仿高德路线规划滑动效果

因为项目有个界面要模仿高德地图路径规划滑动效果&#xff0c;因此写了demo&#xff0c;并简单说下分析过程。高德地图效果演示:仿高德路线规划滑动.gifdemo效果演示:高德地图规划滑动.gif一. 分析首先&#xff0c;我们可以看出这个滚动的视图应该是UIScrollView或者UIScrollVi…

学习Spring Boot:(十八)Spring Boot 中session共享

前言 前面我们将 Redis 集成到工程中来了&#xff0c;现在需要用它来做点实事了。这次为了解决分布式系统中的 session 共享的问题&#xff0c;将 session 托管到 Redis。 正文 引入依赖 除了上篇文章中引入 spring-boot-starter-data-redis&#xff0c;还需要 spring-sess…

学习Spring Boot:(十九)Shiro 中使用缓存

前言 在 shiro 中每次去拦截请求进行权限认证的时候&#xff0c;都会去数据库查询该用户的所有权限信息&#xff0c; 这个时候就是有一个问题了&#xff0c;因为用户的权限信息在短时间内是不可变的&#xff0c;每次查询出来的数据其实都是重复数据&#xff0c;没必要每次都去…

学习Spring Boot:(二十五)使用 Redis 实现数据缓存

前言 由于 Ehcache 存在于单个 java 程序的进程中&#xff0c;无法满足多个程序分布式的情况&#xff0c;需要将多个服务器的缓存集中起来进行管理&#xff0c;需要一个缓存的寄存器&#xff0c;这里使用的是 Redis。 正文 当应用程序要去缓存中读取数据&#xff0c;但是缓存…