一、instanceof关键字的使用:
a instanceof A:判断对象a是否是类A的实例。如果是,返回true;如果不是,返回false。
- 使用场景:为了避免在向下转型时出现ClassCastException的异常,我们在向下转型前,先进行instanceof的判断,一旦返回true,就进行向下转型。如果返回false,不进行向下转型。
- 如果a instanceof A返回true,则a instanceof B也返回true。其中类B是类A的父类。
二、equals()方法的使用:
1.是一个方法,而非运算符
2.只适用于引用数据类型
3.Object类中的equals()的定义:
public boolean equals(Object obj){ return (this == obj); }
说明:Object类中定义的equals()和==的作用是相同的:比较两个对象的地址值是否相同,即两个引用是否指向同一个地址。
4.像String、Date、File、包装类等都重写了object类中的equals()方法。重写以后,比较的不是两个引用的地址是否相同,而是比较两个对象的“实体内容”是否相同。
5.通常情况下,我们自定义的类如果使用equals()的话,也通常是比较两个对象的“实体内容”是否相同,所以我们也需要对object类中的equals()进行重写。
三、toString()的使用:
1.当我们输出一个对象的引用时,实际上就是调用当前对象的toString()
2.Object类中的toString()的定义:
public String toString(){ return getClass().getName()+"@"+Integer.toHexString(hashCode()); }
3.像String、Date、File、包装类等都重写了Object类中的toString()方法。使得在调用对象的toString()时,返回“实体内容”信息。
4.自定义类也可以重写toString()方法,当调用此方法时,返回对象的“实体内容”。
四、单元测试JUnit用法:
在Eclipce中步骤:
- 选中当前工程—>右键:build path——>add libraries——>JUnit4——>下一步
- 创建java类,进行单元测试,此时的java类要求:1.此类是public的。2.此类提供公共的无参的构造器。
- 此时的单元测试方法:权限是public,没有返回值,没有形参
- 此单元测试方法上需要声明注解:@Test,并在单元测试类中导入:import org.junit.Test;
- 声明好单元测试方法后,就可以在方法体内测试相关代码。
- 写完代码后,左键双击单元测试方法名,右键:run as——>JUnit Test
代码例子如下:
public class JUnitTest{ @Test public void testthis(){//双击testthis执行 ... //被测试的内容 } }
五、包装类的使用:
- 针对八中基本数据类型定义相应的引用类型-包装类(封装类)
- 有了类的特点,就可以调用类中的方法,java才是真正的面向对象
1.java提供了8中基本数据类型对应的包装类,是的基本数据类型的变量具有类的特征。
2.基本数据类型、包装类、String三者之间的相互转换:
3.自动装箱和自动拆箱:
自动装箱:基本数据类型——>包装类的对象
代码举例:
int num = 10; Integer in = num;//自动装箱 Integer in = new Integer(num);//手动装箱
自动拆箱:包装类——>基本数据类型
代码举例:
int num1 = num;//自动装箱
4.基本数据类型、包装类——>String类型:调用String重载的valueOf(XXX xxx)或者直接+
举例子:
int num = 10; String str = num + "";//直接+方式 String str2 = String.valueOf(num);//方法
5.String类型——>基本数据类型、包装类:调用包装类的parseXxx(String s)
举例子:
String str = "123"; int num = Integer.parseInt(str);//String转化为int
特别的:Integer内部定义了IntegerCache结构,IntegerCache中定义了Integer【】,保存了从-128~127范围的整数。如果我们使用自动装箱的方式,给Integer赋值的范围在-128~128范围内时,可以直接使用数组中的元素,不再去new了。目的:提高效率。
代码举例说明:
public void test(){ Integer i = new Integer(1); Integer j = new Integer(1); System.out,println(i == j);//false ,因为比较的是地址,new了就是地址不同了 Integer i = 1; Integer j = 1; System.out,println(i == j);//turn,因为是直接使用Integer中定义的数,地址一样 Integer i = 128; Integer j = 128 System.out,println(i == j);//false,因为128超过了127,相当于重新new了,而不是用的方法定义的数,所有地址不同