在日常开发中经常会遇到数字的情况,有关数据的场景中会遇到取整的情况,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类)的更多相关文章

  1. JAVA基础(二)—— 常用的类与方法

    JAVA基础(二)-- 常用的类与方法 1 Math类 abs ceil floor 绝对值 大于等于该浮点数的最小整数 小于等于该浮点数的最大整数 max min round 两参数中较大的 两参数 ...

  2. Java从零开始学二十八(Math类和Random类)

    一.Math概述 提供了常用的数学运算方法和两个静态常量E(自然对数的底数)和PI(圆周率) 二.常用方法 package com.pb.demo1; public class MathTest { ...

  3. Java基础知识强化81:Math类random()方法之获取任意范围的随机数案例(面试题)

    1. 需求:设计一个方法,可以实现获取任意范围内的随机数 分析:使用方法random()如下: public static double random() 注:Returns a pseudo-ran ...

  4. Java基础知识强化80:Math类random()方法的小扩展(控制产生目的数字的概率)

    1. Math.random()方法: Math.random()出现的数据是0.0<= x < 1.0之间,随机出现一个数据Math.random()>0.1概率是0.9 那么如下 ...

  5. Java基础复习笔记系列 五 常用类

    Java基础复习笔记系列之 常用类 1.String类介绍. 首先看类所属的包:java.lang.String类. 再看它的构造方法: 2. String s1 = “hello”: String ...

  6. java 基础知识二 基本类型与运算符

    java  基础知识二 基本类型与运算符 1.标识符 定义:为类.方法.变量起的名称 由大小写字母.数字.下划线(_)和美元符号($)组成,同时不能以数字开头 2.关键字 java语言保留特殊含义或者 ...

  7. java基础(二章)

    java基础(二章) 一,变量 1.变量是内存中的一个标识符号,用于存储数据 2.变量命名规则 l  必须以字母.下划线 _ .美元符号 $ 开头 l  变量中,可以包括数字 l  变量中,不能出现特 ...

  8. Java基础十二--多态是成员的特点

    Java基础十二--多态是成员的特点 一.特点 1,成员变量. 编译和运行都参考等号的左边. 覆盖只发生在函数上,和变量没关系. Fu f = new Zi();System.out.println( ...

  9. Java基础-进程与线程之Thread类详解

    Java基础-进程与线程之Thread类详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.进程与线程的区别 简而言之:一个程序运行后至少有一个进程,一个进程中可以包含多个线程 ...

随机推荐

  1. git clone克隆github仓库慢,问题解决

    导读 转载自:https://www.hangge.com/blog/cache/detail_2670.html 原因     由于国内网络问题,当我们使用 git clone 命令从 github ...

  2. Skip Lists: A Probabilistic Alternative to Balanced Trees 阅读笔记

    论文地址:https://15721.courses.cs.cmu.edu/spring2018/papers/08-oltpindexes1/pugh-skiplists-cacm1990.pdf ...

  3. Docker - 解决同步容器与主机时间报错:Error response from daemon: Error processing tar file(exit status 1): invalid symlink "/usr/share/zoneinfo/UTC" -> "../usr/share/zoneinfo/Asia/Shanghai"

    问题背景 这里讲解了如何同步容器和主机的时间:https://www.cnblogs.com/poloyy/p/13967532.html 其中使用方法二 docker cp /etc/localti ...

  4. SPA 路由三部曲之核心原理

    为了配合单页面 Web 应用快速发展的节奏,近几年,各类前端组件化技术栈层出不穷.通过不断的版本迭代 React.Vue 脱颖而出,成为当下最受欢迎的两大技术栈. 仅 7 个月的时间,两个技术栈的下载 ...

  5. 连续子数组的和的绝对值的最大值、最小值(非绝对值的话直接dp动态规划)

    前缀和的思路: sum[i] = num[0]+num[1]+......+num[i-1] sum[j] = num[0]+num[1]+......+num[j-1] 那么:num[i]+num[ ...

  6. ThreadLocal应用及源码分析

    ThreadLocal 基本使用 ThreadLocal 的作用是:提供线程内的局部变量,不同的线程之间不会相互干扰,这种变量在线程的生命周期内起作用,减少同一个线程内多个函数或组件之间一些公共变量传 ...

  7. Win7 安装 Docker 踩的那些坑

    公司电脑是 WIN7 x64 旗舰版 SP1,安装 Docker 时踩了好多雷,分享出来给大家排排雷. 首先,Docker Desktop Installer 的 Windows 版只支持 Win10 ...

  8. 每天一个linux命令之top

    每天一个linux命令之top 转  https://www.linuxprobe.com/chapter-02.html 在图2-6中,top命令执行结果的前5行为系统整体的统计信息,其所代表的含义 ...

  9. Guitar Pro吉他指弹入门——日式指弹的pm技巧

    在上一篇指弹的文章中,笔者向大家介绍了一下美式指弹,以及他独树一帜的三指法.那么这一期的文章,我将介绍另一个指弹界的大流派--日式指弹,日式指弹曲子向来以细腻而多变的情绪以及表达出来的艳丽色彩著称,今 ...

  10. 「CF578F」 Mirror Box

    description CF578F solution 考虑转化题目的要求 1.对于任意一条边,都存在一条从界垂直射入的光线,经过反射穿过这条边. 当图中有环时,环内的边一定不满足条件,而在不存在环时 ...