一、Math

这个类包含执行指数、对数、平方根法、三角函数等基本的数字运算。

Math中还包含一些静态常量供我们调用。

如PI圆周率,E。

1.abs(),返回该数的绝对值。

public class Test {
public static void main(String[] args) {
System.out.println(Math.abs(1.0));
System.out.println(Math.abs(-1));
System.out.println(Math.abs(-0));
}
}
运行结果:
1.0
1
0

正数的绝对值就是本事,负数的绝对值就是它的相反数,0的绝对值就是0;

Math类中有根据传入的参数类型不同,设置了多个abs函数用于接收不同的类型的参数,并返回对应类型的绝对值。

简而言之就是传递进去的参数是什么类型的,就返回对应类型的绝对值。

2.三角函数(sin,cos,tan)

使用三角函数我们需要角度和弧度之间转换。

三角函数无法直接传递角度进行计算,而是通过传递弧度进行计算。

可以直接自己直接计算,也可以通过调用toRadians()将角度转换为弧度。

源码中对toRadians()的描述:将以度数衡量的角度,转换为近似相等的以弧度衡量的角。

角度与弧度的转换通常是不精确的。

其实自己手动转换通常也是不精确的,在计算机的世界只有相对的准确,没有绝对的精准。

public class Test {
public static void main(String[] args) {
System.out.println(Math.sin(30 * (Math.PI / 180.0)));//1度 = PI / 180弧度,
System.out.println(Math.sin(Math.toRadians(30))); //其实toRadians内部也是这样转换的,
} //传进去的参数作为角度,然后乘以PI / 180
}
运行结果:
0.49999999999999994
0.49999999999999994

sin30度应该是0.5,计算机算的有一定的误差。

剩下的cos 和tan类似。

3.反三角函数(asin(),acos() , atan())。

即三角函数的逆运算,已知值求代表该值的角度。例如sin30度 = 0.5

反三角即arcsin(0.5) = 30度 , arccos,arctan类似。

三角函数返回的值并不是角度,而是弧度所以还需要进行一次角度与弧度直接的转换。

这个也可以自己转换或调用toDegrees()将弧度转化为角度,这个转换也是不精准的。

public class Test {
public static void main(String[] args) {
System.out.println(Math.asin(0.5) / (Math.PI / 180.0));//将返回的弧度,转化为角度。
System.out.println(Math.toDegrees(Math.asin(0.5))); //通过toDgrees转换
}
}
30.000000000000004
30.000000000000004

4.sqrt() 开平方

public class Test {
public static void main(String[] args) {
System.out.println(Math.sqrt(2)); // √2
System.out.println(Math.sqrt(3)); // √3
System.out.println(Math.sqrt(4));
}
}
1.4142135623730951
1.7320508075688772
2.0

这个没什么好说的了,有兴趣的人可以了解下开平方的算法(一般用牛顿迭代法)。

还有一个有趣的代码,雷神之锤开平方代码中的神秘常数。

5.pow(double a, doubel b),求a^b

public class Test {
public static void main(String[] args) {
System.out.println(Math.pow(1, 100)); // 1^100
System.out.println(Math.pow(2, 3));
System.out.println(Math.pow(5, 2.5)); //5^2.5
}
}
运行结果:
1.0
8.0
55.90169943749474

6.ceil()

我们来看下JDK源码中的解释:

返回一个最小值(括号部分没有翻译),它大于或等于(传递进去的)参数

而且它是一个整数。

看着可能有些绕口,我也觉得很绕口...

简而言之就是向上取整。向数值较大的整数靠齐。

也可以说返回在数轴正无穷方向上与参数距离最近的整数。

如果参数是整数,则返回本身。

public class Test {
public static void main(String[] args) {
System.out.println(Math.ceil(-1.2));//往数值较大的整数靠齐,-1 比 -1.2大
System.out.println(Math.ceil(-0.5));//0比-0.5大。
System.out.println(Math.ceil(1));
System.out.println(Math.ceil(1.2));
System.out.println(Math.ceil(1.5));
}
}
运行结果:
-1.0
-0.0
1.0
2.0
2.0

7.floor()

这个刚好和ceil()相反,往数值较小的整数靠齐。

也可以说返回在数轴负无穷方向上与参数距离最近的整数。

如果参数为整数则返回本身。

public class Test {
public static void main(String[] args) {
System.out.println(Math.floor(-1.2));//往数值较小的整数靠齐,-2比 -1.2小
System.out.println(Math.floor(-0.5));//0比-0.5大。
System.out.println(Math.floor(1));
System.out.println(Math.floor(1.2));
System.out.println(Math.floor(1.5));
}
}
运行结果:
-2.0
-1.0
1.0
1.0
1.0

8.round()

简单的说对于正数是四舍五入。

但对于负数是五舍六入,更准确的说应该是对于负数,先去掉负号当做正数,然后五舍六入,最后加上负号。

public class Test {
public static void main(String[] args) {
System.out.println(Math.round(-2.8)); //-3
System.out.println(Math.round(-2.6)); //-3
System.out.println(Math.round(-2.5)); //-2
System.out.println(Math.round(-1.5)); //-1
System.out.println(Math.round(-1.4)); //-1
System.out.println(Math.round(-0.4)); // 0
System.out.println(Math.round(0.4)); // 0
System.out.println(Math.round(1.4)); //1
System.out.println(Math.round(1.5)); //2
System.out.println(Math.round(2.5)); //3
System.out.println(Math.round(2.6)); //3
System.out.println(Math.round(2.8)); //3
}
}
运行结果:
-3
-3
-2
-1
-1
0
0
1
2
3
3
3

还有一些方法就不一 一解释了,有兴趣的可以查阅文档或者看源码及其注释。

二、Random

可以产生随机数,其实计算机中也没有真的随机数。

1. nextInt()和nextInt(int bound)

nextInt()是直接生产int范围内的伪随机数,有2^32种可能。

nextInt(int bound) 生成 [0,boudn) 范围之间的伪随机数,包含0,不包含bound。

public class Test {
public static void main(String[] args) {
Random r = new Random();
for(int i = 0; i < 3; i++){
System.out.println(r.nextInt());//生成随机数
}
for(int i = 0; i < 3; i++){
System.out.println(r.nextInt(10));//生成[0,10)之间的随机数,包含0,不包含10.
}
}
}
运行结果:
442673013
19803501
-388344272
0
2
7

2.nextfloat()与nextdouble()类似,只是返回值类型不同。

nextFloat()返回0.0f~1.0f之间的随机数。

nextDouble()返回0.0 ~ 1.0之间的随机数。(小数默认是double精度)

nextfloat()与nextdouble()源码里面两个方法的注释只写了取0.0~1.0之间的随机数,没有说两端的情况。

netxDouble()和nextFlaot()注释,0.0~1.0之间(between)

而对于一端包含一端不包含的情况nextInt(int boudn)有说明:

包含(inclusive)0 ,不包含(exclusive)指定值(bound)

对于一端包含一端不包含的情况,注释应该会说明。所以注释没有明确说明的我认为是不包含的。

结上所述我认为(0.0,1.0)之间应该是不包含两端。

我在网上查了下,有说包含0.0不包含1.0的,对这种说法我持保留态度。

如果有了解的人士,烦请解惑,不胜感谢!

3.4常用类(java学习笔记)Math和Random的更多相关文章

  1. Java学习笔记-Math类

    并非所有的类都需要main方法.Math类和JOptionPane类都没有main方法.这些类中所包含的方法主要是为了供其他类使用. package welcome; public class Tes ...

  2. java学习笔记7--抽象类与抽象方法

    接着前面的学习: java学习笔记6--类的继承.Object类 java学习笔记5--类的方法 java学习笔记4--类与对象的基本概念(2) java学习笔记3--类与对象的基本概念(1) jav ...

  3. java学习笔记14--多线程编程基础1

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note14.html,转载请注明源地址. 多线程编程基础 多进程 一个独立程序的每一次运行称为 ...

  4. java学习笔记16--I/O流和文件

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note16.html,转载请注明源地址. IO(Input  Output)流 IO流用来处理 ...

  5. java学习笔记13--反射机制与动态代理

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note13.html,转载请注明源地址. Java的反射机制 在Java运行时环境中,对于任意 ...

  6. java学习笔记11--集合总结

    java学习笔记系列: java学习笔记10--泛型总结 java学习笔记9--内部类总结 java学习笔记8--接口总结 java学习笔记7--抽象类与抽象方法 java学习笔记6--类的继承.Ob ...

  7. java学习笔记9--内部类总结

    java学习笔记系列: java学习笔记8--接口总结 java学习笔记7--抽象类与抽象方法 java学习笔记6--类的继承.Object类 java学习笔记5--类的方法 java学习笔记4--对 ...

  8. java学习笔记8--接口总结

    接着前面的学习: java学习笔记7--抽象类与抽象方法 java学习笔记6--类的继承.Object类 java学习笔记5--类的方法 java学习笔记4--对象的初始化与回收 java学习笔记3- ...

  9. java学习笔记之基础篇

    java选择语句之switch   //switch可以用于等值判断 switch (e) //int ,或则可以自动转化成int 的类型,(byte char short)枚举jdk 7中可以防止字 ...

随机推荐

  1. sls语法:创建file,创建文件夹

    http://blog.kukafei520.net/html/2014/942.html /tmp/aaa.txt: file.managed /tmp/salt_test: file.direct ...

  2. Oracle查询字段内容为非数字的记录

    今天在一张3W多记录的表里查非数字的异常数据~数据库太水,记录一发,因为2.5使用人员误输入为2..5.... select t.routecardlist_id,trim(translate(RTR ...

  3. CSS中z-index全解析

    一.z-index解释 z-index属性决定了一个HTML元素的层叠级别,元素层叠级别是相对于元素在Z轴上(与X轴Y轴相对照)的位置而言.一个更高的z-index值意味着这个元素在叠层顺序中会更靠近 ...

  4. 【BZOJ】1596: [Usaco2008 Jan]电话网络

    [算法]树上贪心 [题解] 因为一个点必须被覆盖,那么它如果没有被子树节点覆盖的话,就覆盖它的父节点. 从叶子开始贪心. 注意,如果它自己已经被选了就不需要选父节点了. #include<cst ...

  5. 【mysql优化】语句优化

    1.int型子查询陷阱 如下两个表: mysql> desc user; +----------+-------------+------+-----+---------+-------+ | ...

  6. 使用QML创建第一个界面(转)

    原文转自 https://blog.csdn.net/rl529014/article/details/51378307 在Qt编程中,我们可以使用纯C++代码,或C++和XML结合的方式来创建GUI ...

  7. python面向对象——类和对象

    一.三大编程范式 编程范式即编程的方法论,标识一种编程风格 三大编程范式: 1.面向过程编程(流水线式) 优点:极大的降低了程序的复杂度 缺点:应用场景固定住了,可扩展性差 2.函数式编程 特点: a ...

  8. Cpython解释器支持的进程与线程

    一.理论部分 一 什么是进程 进程:正在进行的一个过程或者说一个任务.而负责执行任务则是cpu. 举例(单核+多道,实现多个进程的并发执行): egon在一个时间段内有很多任务要做:python备课的 ...

  9. linux驱动基础系列--Linux I2c驱动分析

    前言 主要是想对Linux I2c驱动框架有一个整体的把控,因此会忽略协议上的某些细节,同时里面涉及到的一些驱动基础,比如平台驱动.设备模型.sysfs等也不进行详细说明原理,涉及到i2c协议部分也只 ...

  10. Oracle rman 脚本

    1.shell脚本1)vi rman_backup.cmd#rman_backup.cmdconnect target /run{  allocate channel d1 device type d ...