Object 作为超类
Object是类层次结构的根类,所有的类都直接或者间接的继承自Object类。
Object类的构造方法有一个,并且是无参构造,
这其实就是理解当时我们说过,子类构造方法默认访问父类的构造是无参构造
hashCode()和getClass()方法(了解)
package cn.itcast_01; /* * Object:类 Object 是类层次结构的根类。每个类都使用 Object 作为超类。 * 每个类都直接或者间接的继承自Object类。 * * Object类的方法: * public int hashCode():返回该对象的哈希码值。 * 注意:哈希值是根据哈希算法计算出来的一个值,这个值和地址值有关,但是不是实际地址值。 * 你可以理解为地址值。 * * public final Class getClass():返回此 Object 的运行时类 * Class类的方法: * public String getName():以 String 的形式返回此 Class 对象所表示的实体 */ public class StudentTest { public static void main(String[] args) { Student s1 = new Student(); System.out.println(s1.hashCode()); // 11299397 Student s2 = new Student(); System.out.println(s2.hashCode());// 24446859 Student s3 = s1; System.out.println(s3.hashCode()); // 11299397 System.out.println("-----------"); Student s = new Student(); Class c = s.getClass(); System.out.println(c);//class cn.itcast_01.Student String str = c.getName(); System.out.println(str); // cn.itcast_01.Student //链式编程 String str2 = s.getClass().getName(); System.out.println(str2); } }
toString()方法
package cn.itcast_02; /* * public String toString():返回该对象的字符串表示。 * * Integer类下的一个静态方法: * public static String toHexString(int i):把一个整数转成一个十六进制表示的字符串 * * 这个信息的组成我们讲解完毕了,但是这个信息是没有任何意义的。所以,建议所有子类都重写该方法。 * 怎么重写呢? * 把该类的所有成员变量值组成返回即可。 * 重写的最终版方案就是自动生成toString()方法。 * * 注意: * 直接输出一个对象的名称,其实就是调用该对象的toString()方法。 */ public class StudentDemo { public static void main(String[] args) { Student s = new Student(); System.out.println(s.hashCode()); System.out.println(s.getClass()); System.out.println(s.getClass().getName()); System.out.println("--------------------"); System.out.println(s.toString());// cn.itcast_02.Student@42552c System.out.println("--------------------"); // toString()方法的值等价于它 // getClass().getName() + '@' + Integer.toHexString(hashCode()) // this.getClass().getName()+'@'+Integer.toHexString(this.hashCode()) // cn.itcast_02.Student@42552c // cn.itcast_02.Student@42552c System.out.println(s.getClass().getName() + '@' + Integer.toHexString(s.hashCode())); System.out.println(s.toString());//Student [name=null, age=0] // 直接输出对象的名称 System.out.println(s);//Student [name=null, age=0],直接输出对象名称就是调用重写后的toString()方法
} }
重写toString()方法
package cn.itcast_02; public class Student { private String name; private int age; public Student() { super(); } public Student(String name, int age) { super(); this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "Student [name=" + name + ", age=" + age + "]"; } }
快捷方法,右击source-->toString()
equals()方法
快捷方法,右击source-->equals()
package cn.itcast_03; /* * public boolean equals(Object obj):指示其他某个对象是否与此对象“相等”。 * 这个方法,默认情况下比较的是地址值。比较地址值一般来说意义不大,所以我们要重写该方法。 * 怎么重写呢? * 一般都是用来比较对象的成员变量值是否相同。 * 重写的代码优化:提高效率,提高程序的健壮性。 * 最终版: * 其实还是自动生成。 * * 看源码: * public boolean equals(Object obj) { * //this - s1 * //obj - s2 * return (this == obj); * } * * ==: * 基本类型:比较的就是值是否相同 * 引用类型:比较的就是地址值是否相同 * equals: * 引用类型:默认情况下,比较的是地址值。 * 不过,我们可以根据情况自己重写该方法。一般重写都是自动生成,比较对象的成员变量值是否相同 */ public class StudentDemo { public static void main(String[] args) { Student s1 = new Student("林青霞", 27); Student s2 = new Student("林青霞", 27); System.out.println(s1 == s2); // false Student s3 = s1; System.out.println(s1 == s3);// true System.out.println("---------------"); System.out.println(s1.equals(s2)); // obj = s2; //false System.out.println(s1.equals(s1)); // true System.out.println(s1.equals(s3)); // true Student s4 = new Student("风清扬",30); System.out.println(s1.equals(s4)); //false Demo d = new Demo(); System.out.println(s1.equals(d)); } } class Demo {}
finalize()和clone()方法,了解
package cn.itcast_04; /* * protected void finalize():当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。用于垃圾回收,但是什么时候回收不确定。 * protected Object clone():创建并返回此对象的一个副本。 * A:重写该方法 * * Cloneable:此类实现了 Cloneable 接口,以指示 Object.clone() 方法可以合法地对该类实例进行按字段复制。 * 这个接口是标记接口,告诉我们实现该接口的类就可以实现对象的复制了。 * 让被克隆的类实现该接口,才可以克隆 */ public class StudentDemo { public static void main(String[] args) throws CloneNotSupportedException { //创建学生对象 Student s = new Student(); s.setName("林青霞"); s.setAge(27); //克隆学生对象 Object obj = s.clone(); Student s2 = (Student)obj; System.out.println("---------"); System.out.println(s.getName()+"---"+s.getAge()); System.out.println(s2.getName()+"---"+s2.getAge()); //以前的做法 Student s3 = s; System.out.println(s3.getName()+"---"+s3.getAge()); System.out.println("---------"); //其实是有区别的,克隆出来的,和原来的没关系;两个引用,改动其中一个,另一个也会变 s3.setName("刘意"); s3.setAge(30); System.out.println(s.getName()+"---"+s.getAge()); System.out.println(s2.getName()+"---"+s2.getAge()); System.out.println(s3.getName()+"---"+s3.getAge()); } }
protected Object clone():创建并返回此对象的一个副本。
* A:重写该方法
Cloneable:此类实现了 Cloneable 接口,以指示 Object.clone() 方法可以合法地对该类实例进行按字段复制。
* 这个接口是标记接口,告诉我们实现该接口的类就可以实现对象的复制了。
* 让被克隆的类实现该接口,才可以克隆
package cn.itcast_04; public class Student implements Cloneable { private String name; private int age; public Student() { super(); } public Student(String name, int age) { super(); this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } }