一般情况下我们会使用数据的基本数据类型: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 包。
下面是一个装箱与拆箱的例子:
publicclassTest{
publicstaticvoidmain(Stringargs[]){
Integerx=5;//boxesinttoanIntegerobject
x=x+10;//unboxestheIntegertoaint
System.out.println(x);
}
}
以上实例编译运行结果如下:
15
当x被赋为整型值时,由于 x 是一个对象,所以编译器要对x进行装箱。然后,为了使x能进行加运算,所以要对x进行拆箱。
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 | toDegrees()将参数转化为角度。 | |||||
26 | toRadians()将角度转换为弧度。 | |||||
27 | random()返回一个随机数。 |