Java Number类
一般情况下我们会使用数据的基本数据类型:byte、int、short、long、double、float、boolean、char;
对应的包装类型也有八种:Byte、Integer、Short、Long、Double、Float、Character、Boolean;
包装类型都是用 final 声明了,不可以被继承重写;在实际情况中编译器会自动的将基本数据类型装箱成对象类型,或者将对象类型拆箱成基本数据类型;如下:public static void main(String[] args) {
int num1 = 1;
//将基本数据类型装箱成对象包装类型
Integer num2 = num1;
Integer num3 = 3;
//将对象数据类拆箱
int num4 = num3;
}
Number 类是 java.lang 包下的一个抽象类,提供了将包装类型拆箱成基本类型的方法,所有基本类型(数据类型)的包装类型都继承了该抽象类,并且是final声明不可继承改变;package java.lang;
public abstract class Number implements java.io.Serializable {
public abstract int intValue();
public abstract long longValue();
public abstract float floatValue();
public abstract double doubleValue();
public byte byteValue() {
return (byte)intValue();
}
public short shortValue() {
return (short)intValue();
}
private static final long serialVersionUID = -8742448824652078965L;
}
包装类
基本数据类型
Boolean
boolean
Byte
byte
Short
short
Integer
int
Long
long
Character
char
Float
float
Double
double
这种由编译器特别支持的包装称为装箱,所以当内置数据类型被当作对象使用的时候,编译器会把内置类型装箱为包装类。相似的,编译器也可以把一个对象拆箱为内置类型。Number 类属于 java.lang 包。
下面是一个装箱与拆箱的例子:public class Test{
public static void main(String args[]){
Integer x = 5; // boxes int to an Integer object
x = x + 10; // unboxes the Integer to a int
System.out.println(x);
}
}
以上实例编译运行结果如下:15
当x被赋为整型值时,由于 x 是一个对象,所以编译器要对x进行装箱。然后,为了使x能进行加运算,所以要对x进行拆箱。
Java Math类
Java 的 Math 包含了用于执行基本数学运算的属性和方法,如初等指数、对数、平方根和三角函数。
Math 的方法都被定义为 static 形式,通过 Math 类可以在主函数中直接调用。
实例public class Test {
public static void main (String []args)
{
System.out.println("90 度的正弦值:" + Math.sin(Math.PI/2));
System.out.println("0度的余弦值:" + Math.cos(0));
System.out.println("60度的正切值:" + Math.tan(Math.PI/3));
System.out.println("1的反正切值: " + Math.atan(1));
System.out.println("π/2的角度值:" + Math.toDegrees(Math.PI/2));
System.out.println(Math.PI);
}
}
以上实例编译运行结果如下:90 度的正弦值:1.0
0度的余弦值:1.0
60度的正切值:1.7320508075688767
1的反正切值: 0.7853981633974483
π/2的角度值:90.0
3.141592653589793
Number & Math 类方法
下面的表中列出的是常用的 Number 类和 Math 类的方法:
序号
方法与描述
1
xxxValue()
将number对象转换为xxx数据类型的值并返回。
2
compareTo()将number对象与参数比较。
3
equals()
判断number对象是否与参数相等。
4
valueOf()返回一个Integer对象指定的内置数据类型
5
toString()以字符串形式返回值。
6
parseInt()将字符串解析为int类型。
7
abs()返回参数的绝对值。
8
ceil()返回大于等于( >= )给定参数的的最小整数,类型为双精度浮点型。
9
floor()返回小于等于(<=)给定参数的最大整数 。
10
rint()返回与参数最接近的整数。返回类型为double。
11
round()返回一个最接近的int、long型值。
12
min()返回两个参数中的最小值。
13
max()返回两个参数中的最大值。
14
exp()返回自然数底数e的参数次方。
15
log()返回参数的自然数底数的对数值。
16
pow()返回第一个参数的第二个参数次方。
17
sqrt()求参数的算术平方根。
18
sin()求指定double类型参数的正弦值。
19
cos()求指定double类型参数的余弦值。
20
tan()求指定double类型参数的正切值。
21
asin()
求指定double类型参数的反正弦值。
22
acos()求指定double类型参数的反余弦值。
23
atan()求指定double类型参数的反正切值。
24
atan2()
将笛卡尔坐标转换为极坐标,并返回极坐标的角度值。
25
26
27
random()
返回一个随机数。