Object类
Object是所有类的父类,所有类都可以用使用其属性和方法
*
* ==
* 基本数据类型:判断的是值是否相等
* 引用数据类型:判断的是引用数据类型再堆里面的地址值是否相等
*equals :只能比较引用数据类型
* 如果没有重写equals方法,比较对象在堆里面的属性值是否相等
* 重写后的equals方法,比较的是属性值
1 package demo1;
2
3 import org.junit.Test;
4
5 public class TestObject {
6 /**
7 * Object是所有类的父类。也就代表所有类都可以使用object提供的方法和属性
8 */
9 @Test
10 public void test(){
11
12 /**
13 * ==
14 * 基本数据类型:判断的是值是否相等
15 * 引用数据类型:判断是引用数据类型在堆里面的地址值是否相等
16 */
17 int a=10;
18 int b=10;
19 System.out.println(a==b);//true
20
21 Object o=new Object();
22 Object o1=new Object();
23 System.out.println(o==o1);//false
24
25 Object o2=o;
26 System.out.println(o2==o);//true
27
28 //equals:只能比较引用数据类型
29 //如果没有重写equals方法,比较是两个对象在堆里面的地址值是否相等
30 //重写后equals方法。必须的是两个对象的属性值是否相同
31 Student stu=new Student("张三");
32 Student stu1=new Student("张三");
33 //发现equals方法依旧比较的是堆里面的地址值是否相同
34 System.out.println(stu.equals(stu1));//
35
36 String str=new String("张三");
37 String str1=new String("张三");
38 System.out.println(str.equals(str1));//
39
40 /**
41 * toString():当我打印一个对象时,默认会调用toString方法,如果没有重写toString方法
42 * 打印的是堆里面的地址值,如果重写后,打印的是属性值
43 */
44 Student stu2=new Student("李四");
45 System.out.println(stu2.toString());
46
47 }
48
49 }
50
51 class Student{
52 private String name;
53
54 public String getName() {
55 return name;
56 }
57
58 public void setName(String name) {
59 this.name = name;
60 }
61
62 public Student(String name) {
63 super();
64 this.name = name;
65 }
66
67 public Student() {
68 super();
69 }
70
71 @Override
72 public String toString() {
73 return "Student [name=" + name + "]";
74 }
75
76
77 }
运行截图:
方法:
一、clone()方法
保护方法,实现对象的浅复制,只有实现了Cloneable接口才可以调用该方法,否则抛出CloneNotSupportedException异常。
主要是JAVA里除了8种基本类型传参数是值传递,其他的类对象传参数都是引用传递,我们有时候不希望在方法里讲参数改变,这是就需要在类中复写clone方法(实现深复制)。
1.1、clone与copy的区别
1.2、clone方法的保护机制
1.3、clone方法的使用
什么时候使用shallow Clone,什么时候使用deep Clone,这个主要看具体对象的域是什么性质的,基本型别还是reference variable
二、toString()方法
例子:
<span data-wiz-span="data-wiz-span" style="font-size: 1.167rem;">package com.cal.toString; public class Test1 { public static void main(String[] args){ Object o1 = new Object(); System.out.println(o1.toString()); } } </span>
三、getClass()方法
四、finalize()方法
该方法用于释放资源。因为无法确定该方法什么时候被调用,很少使用。
Java允许在类中定义一个名为finalize()的方法。它的工作原理是:一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其finalize()方法。并且在下一次垃圾回收动作发生时,才会真正回收对象占用的内存。
关于垃圾回收,有三点需要记住:
1、对象可能不被垃圾回收。只要程序没有濒临存储空间用完的那一刻,对象占用的空间就总也得不到释放。
2、垃圾回收并不等于“析构”。
3、垃圾回收只与内存有关。使用垃圾回收的唯一原因是为了回收程序不再使用的内存。
finalize()的用途:
无论对象是如何创建的,垃圾回收器都会负责释放对象占据的所有内存。这就将对finalize()的需求限制到一种特殊情况,即通过某种创建对象方式以外的方式为对象分配了存储空间。
不过这种情况一般发生在使用“本地方法”的情况下,本地方法是一种在Java中调用非Java代码的方式。
五、equals()方法
如果是同一块内存,则object中的equals方法返回true,如果是不同的内存,则返回false
如果希望不同内存但相同内容的两个对象equals时返回true,则我们需要重写父类的equal方法
String类已经重写了object中的equals方法(这样就是比较内容是否相等了)
六、hashCode()方法
该方法用于哈希查找,可以减少在查找中使用equals的次数,重写了equals方法一般都要重写hashCode方法。这个方法在一些具有哈希功能的Collection中用到。
一般必须满足obj1.equals(obj2)==true。可以推出obj1.hash- Code()==obj2.hashCode(),但是hashCode相等不一定就满足equals。不过为了提高效率,应该尽量使上面两个条件接近等价。
如果不重写hashcode(),在HashSet中添加两个equals的对象,会将两个对象都加入进去。
七、wait()方法
1)wait()
2)wait(long timeout)
3)wait(long timeout,int naos)
什么意思呢?
方法中的异常:
wait方法就是使当前线程等待该对象的锁,当前线程必须是该对象的拥有者,也就是具有该对象的锁。wait()方法一直等待,直到获得锁或者被中断。wait(long timeout)设定一个超时间隔,
如果在规定时间内没有获得锁就返回。
调用该方法后当前线程进入睡眠状态,直到以下事件发生。
(1)其他线程调用了该对象的notify方法。
(2)其他线程调用了该对象的notifyAll方法。
(3)其他线程调用了interrupt中断该线程。
(4)时间间隔到了。
此时该线程就可以被调度了,如果是被中断的话就抛出一个InterruptedException异常。
八、notify()方法
该方法唤醒在该对象上等待的某个线程。
九、notifyAll方法
该方法唤醒在该对象上等待的所有线程。
来源:https://www.cnblogs.com/zhangyinhua/p/7715486.html#_label0