09.int和Integer有什么区别
- int是基础数据类型,字节长度为4,它的创建不会在堆内存中开辟空间,一般保存在栈内存里,可以用算术运算符进行加减乘除等操作。在参数传递的时候,直接传递它的值。
- Integer是int的包装类,而本质是一个类,它的创建会在堆内存中开辟一块新的空间。它的含义也是表示一个整型的数字,但是,算术运算符不能操作它。在参数传递的时候,传递的是它所代表的对象的一个引用。
10.如何用BigDecimal类进行精确运算
使用BigDecimal类来进行精确的算术计算,也就是使用它所提供的一系列的API,主要分为以下步骤:
- 用float或double变量构建BigDecimal对象
- 通过调用BigDecimal的加、减、乘、除等相应的方法进行算术运算
- 把BigDecimal对象转换成float、double、int等类型
- 一般来说,可以用BigDecimal的构造方法或静态的valueOf()方法把基本类型的变量或其字符串构建成BigDecimal对象,例如下面的代码:
BigDecimal v1 = new BigDecimal(Double.toString(0.05));
BigDecimal v2 = BigDecimal.valueOf(0.01); - 对于常用的加、减、乘、除运算,BigDecimal提供了相应的成员方法。它们都是把运算的操作对象作为参数传入,与自身进行相应的计算,并且返回计算后的值,代码如下:
public BigDecimal add(BigDecimal augend) //加法
public BigDecimal subtract(BigDecimal augend) //减法
public BigDecimal multiply(BigDecimal augend) //乘法
public BigDecimal divide(BigDecimal augend) //除法 - 进行相应的计算以后,可能会需要将BigDecimal对象转换成相应的基本数据类型的变量,就可以调用floatValue()、doubleValue()等方法。以下是一段使用BigDecimal进行运算的示例代码:
public class BigDecimalTest {
public static void main(String[] args){
System.out.println(add(0.05,0.01));
}
//提供精确加法计算的add方法
public static double add(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.add(b2).doubleValue();
}
}
11.Java可以用非0来代表true吗
Java不能用非0代表true,也不能用0代表false,只能用布尔型的true和false来进行条件判断
12.字符串字面量是否自动生成一个String对象
答案是肯定的。字符串类具有一定的特殊性,JVM在执行双引号操作符的时候,会自动创建一个String对象,并返回这个对象的引用。
13.String、StringBuffer和StringBuilder的区别
String是不可变的,StringBuffer是可变的;StringBuffer是线程安全的,StringBuilder是非线程安全的。
因而在大部分情况下字符串的拼接速度为:StringBuilder > StringBuffer > String
解释如下:
- String是不可变的(通过ide的debugger可以发现其属性大都为final类型),因此每次对其操作改变其变量值,其实是生成一个新的对象,然后将变量引用指向新对象;因此速度慢。
- StringBuffer则不同,对其操作即直接操作对象指向的引用,无需产生新对象,速度很快;它是线程安全的,在维护多线程的同步等也会消耗一点性能。
- StringBuilder是jdk5之后新增的,其用法与StringBuffer完全一致,但它是线程不安全的,在单线程中最佳,因为其不需要维护线程的安全,因此是最快的。