java基础之二:取整函数(Math类)
在日常开发中经常会遇到数字的情况,有关数据的场景中会遇到取整的情况,java中提供了取整函数。看下java.lang.Math类中取整函数的用法。
一、概述
java.lang.Math类中有三个和取整相关的函数,分别是ceil()、floor()、round()方法。所谓取整就是舍弃小数位,保留整数位,但是如何舍弃和保留每个方法的处理方式不一样,看其具体用法。
二、详述
ceil()方法
ceil方法的作用是向上取整。下面看方法的定义,

接收一个double类型的参数,返回double类型。
正数情况
下面看参数为正数的情况,ceil是如何取整的,
package com.example.demo.test;
public class TestMathCeilPost {
public static void main(String[] args) {
//定义double类型
double b=12.5;
double b2=12.1;
//向上取整
double d=Math.ceil(b);
double d2=Math.ceil(b2);
//转化为int类型
int a=Double.valueOf(d).intValue();
int a2=Double.valueOf(d2).intValue();
System.out.println(b+"调用Math.ceil方法后的值为:"+a);
System.out.println(b2+"调用Math.ceil方法后的值为:"+a2);
}
}
看执行结果,

通过上面的结果,可以看到在正数情况下是向上取整,也就是大于原始结果的最小的正数,
负数情况
看负数的情况,
package com.example.demo.test;
public class TestMathCeilNegative {
public static void main(String[] args) {
//定义double类型
double b=-12.5;
double b2=-12.1;
//向上取整
double d=Math.ceil(b);
double d2=Math.ceil(b2);
//转化为int类型
int a=Double.valueOf(d).intValue();
int a2=Double.valueOf(d2).intValue();
System.out.println(b+"调用Math.ceil方法后的值为:"+a);
System.out.println(b2+"调用Math.ceil方法后的值为:"+a2);
}
}
看执行结果,

可以看出也是取大于给定数的最小的负整数。
floor()
ceil方法的作用是向下取整,看方法定义如下,

正数情况
看正数情况下,
package com.example.demo.test;
public class TestMathFloorPost {
public static void main(String[] args) {
//定义double类型
double b=12.5;
double b2=12.1;
//向下取整
double d=Math.floor(b);
double d2=Math.floor(b2);
//转化为int类型
int a=Double.valueOf(d).intValue();
int a2=Double.valueOf(d2).intValue();
System.out.println(b+"调用Math.floor方法后的值为:"+a);
System.out.println(b2+"调用Math.floor方法后的值为:"+a2);
}
}
看执行结果,

通过上面的结果,可以看到floor方法在正数情况下,是取小于给定数的最大的正数。
负数情况
看负数情况下,
package com.example.demo.test;
public class TestMathFloorNegative {
public static void main(String[] args) {
//定义double类型
double b=-12.5;
double b2=-12.1;
//向下取整
double d=Math.floor(b);
double d2=Math.floor(b2);
//转化为int类型
int a=Double.valueOf(d).intValue();
int a2=Double.valueOf(d2).intValue();
System.out.println(b+"调用Math.floor方法后的值为:"+a);
System.out.println(b2+"调用Math.floor方法后的值为:"+a2);
}
}
看执行结果,

通过上面的结果,可以看到floor方法在负数情况下,是取小于给定数的最大的正数。
round()
round方法的作用是“四舍五入”,看方法定义,

看到方法的入参有float、double,出参对应这int、long。以double为例。
正数情况
看正数的情况,
package com.example.demo.test;
public class TestMathRoundPost {
public static void main(String[] args) {
//定义double类型
double b=12.5;
double b2=12.1;
//向上取整
double d=Math.round(b);
double d2=Math.round(b2);
//转化为int类型
int a=Double.valueOf(d).intValue();
int a2=Double.valueOf(d2).intValue();
System.out.println(b+"调用Math.round方法后的值为:"+a);
System.out.println(b2+"调用Math.round方法后的值为:"+a2);
}
}
看执行结果,

看执行结果就是进行数学上的四舍五入运算,得到结果。
负数情况
看负数情况,
package com.example.demo.test;
public class TestMathRoundNegative {
public static void main(String[] args) {
//定义double类型
double b=-12.6;
double b2=-12.1;
double b3=-12.5;
double d=Math.round(b);
double d2=Math.round(b2);
double d3=Math.round(b3);
//转化为int类型
int a=Double.valueOf(d).intValue();
int a2=Double.valueOf(d2).intValue();
int a3=Double.valueOf(d3).intValue();
System.out.println(b+"调用Math.round方法后的值为:"+a);
System.out.println(b2+"调用Math.round方法后的值为:"+a2);
System.out.println(b3+"调用Math.round方法后的值为:"+a3);
}
}
看执行结果,

从上面的结果可以看到,在负数情况下不是简单的“四舍五入”,而要考虑XXX.5的情况,小数位上的数字小于等于5,舍弃小数位,保留整数位数;小数位上的数字大于5,舍弃小数位且加-1;
三、总结
本文分析了Math类中的ceil、floor、round函数,
ceil
正数和负数情况下都是向上取整,这里的向上指的是取大于给定数字的最小整数,例,ceil(12.3)-->13.0 ceil(-12.6)-->-12.0
floor
正数和负数情况下都是向下取整,这里的向下指的是取小于给定数字的最大整数,例,floor(12.3)-->12.0 floor(-12.6)-->-13.0
round
正数情况下是数学上的四舍五入,例,round(12.3)-->12 round(12.5)-->13
正数情况下需要注意小数位的数字,小于等于5,则舍去小数位;大于5,则加-1,例,round(-12.3)-->-12 round(-12.5)-->-12 round(-12.6)-->-13
有不正之处,欢迎指正,感谢!
java基础之二:取整函数(Math类)的更多相关文章
- JAVA基础(二)—— 常用的类与方法
JAVA基础(二)-- 常用的类与方法 1 Math类 abs ceil floor 绝对值 大于等于该浮点数的最小整数 小于等于该浮点数的最大整数 max min round 两参数中较大的 两参数 ...
- Java从零开始学二十八(Math类和Random类)
一.Math概述 提供了常用的数学运算方法和两个静态常量E(自然对数的底数)和PI(圆周率) 二.常用方法 package com.pb.demo1; public class MathTest { ...
- Java基础知识强化81:Math类random()方法之获取任意范围的随机数案例(面试题)
1. 需求:设计一个方法,可以实现获取任意范围内的随机数 分析:使用方法random()如下: public static double random() 注:Returns a pseudo-ran ...
- Java基础知识强化80:Math类random()方法的小扩展(控制产生目的数字的概率)
1. Math.random()方法: Math.random()出现的数据是0.0<= x < 1.0之间,随机出现一个数据Math.random()>0.1概率是0.9 那么如下 ...
- Java基础复习笔记系列 五 常用类
Java基础复习笔记系列之 常用类 1.String类介绍. 首先看类所属的包:java.lang.String类. 再看它的构造方法: 2. String s1 = “hello”: String ...
- java 基础知识二 基本类型与运算符
java 基础知识二 基本类型与运算符 1.标识符 定义:为类.方法.变量起的名称 由大小写字母.数字.下划线(_)和美元符号($)组成,同时不能以数字开头 2.关键字 java语言保留特殊含义或者 ...
- java基础(二章)
java基础(二章) 一,变量 1.变量是内存中的一个标识符号,用于存储数据 2.变量命名规则 l 必须以字母.下划线 _ .美元符号 $ 开头 l 变量中,可以包括数字 l 变量中,不能出现特 ...
- Java基础十二--多态是成员的特点
Java基础十二--多态是成员的特点 一.特点 1,成员变量. 编译和运行都参考等号的左边. 覆盖只发生在函数上,和变量没关系. Fu f = new Zi();System.out.println( ...
- Java基础-进程与线程之Thread类详解
Java基础-进程与线程之Thread类详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.进程与线程的区别 简而言之:一个程序运行后至少有一个进程,一个进程中可以包含多个线程 ...
随机推荐
- 基于FFmpeg的Dxva2硬解码及Direct3D显示(五)
解码及显示 目录 解码及显示 解码 显示 资源清理 解码 循环读取视频帧 AVPacket packet = { 0 }; while (av_read_frame(m_pFmtCtx, &p ...
- 2w+长文带你剖析ConcurrentHashMap~!
并发编程实践中,ConcurrentHashMap是一个经常被使用的数据结构,相比于Hashtable以及Collections.synchronizedMap(),ConcurrentHashMap ...
- tomcat设置好环境变量,依然无法通过cmd startup命令启动
Windows环境下JDK安装与环境变量配置详细的图文教程 https://www.cnblogs.com/liuhongfeng/p/4177568.html Windows环境下maven 环 ...
- [LeetCode题解]160. 相交链表 | 双指针 + 哈希表
方法一:双指针 解题思路 假设链表存在相交时,headA 的长度为 a + c,headB 的长度为 b + c.如果把 headA 连上 headB,headB 连上 headB 的话,当遍历这两个 ...
- 使用Java将XSL和XML文件输出为HTML(XSL学习笔记二)
XSL 指扩展样式表语言(EXtensible Stylesheet Language),前面一篇博客介绍了使用XSL即可直接将XML输出为HTML片段被浏览器解析,但是这样在web应用中浏览器的解析 ...
- Unity CommandBuffer物体轮廓
1.command buffer具有很高的灵活性,它的作用是预定义一些渲染指令,然后在我们想要执行的时候去执行这些指令(见图1),绿点表示可以在"Forward Rendering Path ...
- 通过shodan搜索相同favicon.ico的网站
0x01 根据favicon.ico生成hash python2,想改python3折腾了半天不得 import mmh3 import requests response = requests.ge ...
- Cypress系列(90)- Cypress.Cookies 命令详解以及如何跨测试用例共享 Cookies
如果想从头学起Cypress,可以看下面的系列文章哦 https://www.cnblogs.com/poloyy/category/1768839.html Cypress.Cookies 共有三个 ...
- laravel数据填充
post表有这2个字段 填充20条数据, 执行 php artisan tinker 执行预览 factory(App\Post::class,20)->make(); 插入数据库 factor ...
- jquery删除文件
1 <div class="panel panel-default"> 2 <div class="panel-body"> 3 < ...