• Java Object 类


       

    目录

    一、Object 类的方法

    二、示例

    2.1、clone() 

    2.2、equals() 

    2.3、finalize() 

    2.4、getClass()

    2.5、hashCode() 

    2.6、notify() 与wait() 

    2.7、notifyAll() 与wait() 

    2.8、toString() 


       Java 中有一个比较特殊的类,就是 Object 类,它是所有类的父类。如果一个类没有使用 extends 关键字明确标识继承另外一个类,那么这个类就是默认继承 Object类。因此,Object 类是 Java 类层中最高层的类,是所有类的超类。换句话说, Java 中任何一个类都是它的子类。由于所有类都是 Object 衍生出来的,所以 Objetc 类中的方法适用于所有类。

    1. public class Person { // 当没有指定父类,会默认 Object 类为其父类
    2. }

    等价于

    1. public class Person extends Object{
    2. }

    一、Object 类的方法

    序号方法 & 描述
    1

    protected Object clone()

    创建并返回一个对象的拷贝

    2

    boolean equals(Object obj)

    比较两个对象是否相等

    3

    protected void finalize()

    当 GC (垃圾回收器)确定不存在对该对象的有更多引用时,由对象的垃圾回收器调用此方法。

    4

    Class getClass()

    获取对象的运行时对象的类

    5

    int hashCode()

    获取对象的 hash 值

    6

    void notify()

    唤醒在该对象上等待的某个线程

    7

    void notifyAll()

    唤醒在该对象上等待的所有线程

    8

    String toString()

    返回对象的字符串表示形式

    9

    void wait()

    让当前线程进入等待状态。直到其他线程调用此对象的 notify() 方法或 notifyAll() 方法。

    10

    void wait(long timeout)

    让当前线程处于等待(阻塞)状态,直到其他线程调用此对象的 notify() 方法或 notifyAll() 方法,或者超过参数设置的timeout超时时间。

    11

    void wait(long timeout, int nanos)

    与 wait(long timeout) 方法类似,多了一个 nanos 参数,这个参数表示额外时间(以纳秒为单位,范围是 0-999999)。 所以超时的时间还需要加上 nanos 纳秒。

    二、示例

    2.1、clone() 

            创建并返回一个对象的拷贝。

            clone 方法是浅拷贝,对象内属性引用的对象只会拷贝引用地址,而不会将引用的对象重新分配内存,相对应的深拷贝则会连引用的对象也重新创建。

    1. public class Main implements Cloneable {
    2. // 声明变量
    3. String name;
    4. int age;
    5. public static void main(String[] args) {
    6. // 创建对象
    7. Main obj1 = new Main();
    8. // 初始化变量
    9. obj1.name = "张三";
    10. obj1.age = 28;
    11. // 打印输出
    12. System.out.println("obj1 姓名:"+obj1.name +" 年龄"+obj1.age ); // 张三 28
    13. try {
    14. // 创建 obj1 的拷贝
    15. Main obj2 = (Main) obj1.clone();
    16. // 使用 obj2 输出变量
    17. System.out.print("obj2 姓名:"+obj2.name + " 年龄"+ obj2.age); // 张三
    18. } catch (Exception e) {
    19. System.out.println(e);
    20. }
    21. }
    22. }

    控制台显示

    1. obj1 姓名:张三 年龄28
    2. obj2 姓名:张三 年龄28

    2.2、equals() 

            用于比较两个对象是否相等。

            equals()  方法比较两个对象,是判断两个对象引用指向的是同一个对象,即比较 2 个对象的内存地址是否相等。

    1. public class Main {
    2. public static void main(String[] args) {
    3. // Object 类使用 equals() 方法
    4. // 创建两个对象
    5. Object obj1 = new Object();
    6. Object obj2 = new Object();
    7. // 判断 obj1 与 obj2 是否相等
    8. // 不同对象,内存地址不同,不相等,返回 false
    9. System.out.println(obj1.equals(obj2)); // false
    10. // obj1 赋值给 obj3
    11. // String 重写了 equals() 方法
    12. // 对象引用,内存地址相同,相等,返回 true
    13. Object obj3 = obj1;
    14. System.out.println(obj1.equals(obj3)); // true
    15. }
    16. }

    2.3、finalize() 

            用于实例被垃圾回收器回收的时触发的操作。

            当 GC (垃圾回收器) 确定不存在对该对象的有更多引用时,对象的垃圾回收器就会调用这个方法。

    1. public class FinalizeTest {
    2. public static void main(String[] args) {
    3. //多造点垃圾,让垃圾回收器启动
    4. for(int i = 0; i < 10000000; i++) {
    5. //创建对象
    6. Person p = new Person();
    7. //把Person对象变成垃圾
    8. p = null;
    9. }
    10. }
    11. }
    12. class Person{
    13. //重写finalize()方法
    14. //Person类型的对象被垃圾回收器回收的时候,垃圾回收器负责调用p.finalize();
    15. protected void finalize() throws Throwable {
    16. System.out.println("即将被销毁!");
    17. }
    18. }

    2.4、getClass()

            Object getClass() 方法用于获取对象的运行时对象的类。

    1. import java.util.ArrayList;
    2. import java.util.GregorianCalendar;
    3. public class Main extends GregorianCalendar {
    4. public static void main(String[] args) {
    5. // getClass() with Object
    6. Object obj1 = new Object();
    7. System.out.println("obj1 的类为: " + obj1.getClass());
    8. // getClass() with String
    9. String obj2 = new String();
    10. System.out.println("obj2 的类为: " + obj2.getClass());
    11. // getClass() with ArrayList
    12. ArrayList obj3 = new ArrayList<>();
    13. System.out.println("obj3 的类为: " + obj3.getClass());
    14. // 创建 RunoobTest 类的对象
    15. Main m = new Main();
    16. System.out.println("Main 的类为: " +m.getClass());
    17. }
    18. }

    控制台显示

    1. obj1 的类为: class java.lang.Object
    2. obj2 的类为: class java.lang.String
    3. obj3 的类为: class java.util.ArrayList
    4. Main 的类为: class com.day03.Main

    2.5、hashCode() 

            Object hashCode() 方法用于获取对象的 hash 值。

    1. public class Main{
    2. public static void main(String[] args) {
    3. // Object 使用 hashCode()
    4. Object obj1 = new Object();
    5. System.out.println(obj1.hashCode());
    6. Object obj2 = new Object();
    7. System.out.println(obj2.hashCode());
    8. Object obj3 = new Object();
    9. System.out.println(obj3.hashCode());
    10. }
    11. }

    控制台显示

    1. 1023487453
    2. 1651191114
    3. 1586600255

    2.6、notify() 与wait() 

            Object notify() 方法用于唤醒一个在此对象监视器上等待的线程。

            如果所有的线程都在此对象上等待,那么只会选择一个线程,选择是任意性的,并在对实现做出决定时发生。

            Object wait() 方法让当前线程进入等待状态。直到其他线程调用此对象的 notify() 方法或 notifyAll() 方法。

    等待线程

    1. public class WaitThread implements Runnable{
    2. Object lock;
    3. public WaitThread(Object lock){
    4. this.lock = lock;
    5. }
    6. public void run() {
    7. String threadName = Thread.currentThread().getName();
    8. synchronized (lock){
    9. System.out.println(threadName + "开始进入同步代码块区域");
    10. try {
    11. lock.wait();
    12. } catch (InterruptedException e) {
    13. e.printStackTrace();
    14. }
    15. System.out.println(threadName + "准备离开同步代码块区域");
    16. }
    17. }
    18. }

    唤醒线程

    1. public class NotifyThread implements Runnable{
    2. Object lock;
    3. public NotifyThread(Object lock){
    4. this.lock = lock;
    5. }
    6. public void run() {
    7. String threadName = Thread.currentThread().getName();
    8. synchronized (lock){
    9. System.out.println(threadName + "开始进入同步代码块区域");
    10. lock.notify();
    11. try {
    12. System.out.println(threadName + "业务处理开始");
    13. // 暂停 2s 表示业务处理
    14. Thread.sleep(2000);
    15. System.out.println(threadName + "业务处理结束");
    16. } catch (InterruptedException e) {
    17. e.printStackTrace();
    18. }
    19. System.out.println(threadName + "准备离开同步代码块区域");
    20. //lock.notify();放在这一行唤醒,效果一样
    21. }
    22. try {
    23. Thread.sleep(5000);
    24. } catch (InterruptedException e) {
    25. e.printStackTrace();
    26. }
    27. System.out.println(threadName + "退出同步代码块后续操作");
    28. }
    29. }

    主程序

    1. public class Main {
    2. public static void main(String[] args) throws InterruptedException {
    3. Object lock = new Object();
    4. Thread waitThread = new Thread(new WaitThread(lock), "waitThread");
    5. Thread notifyThread = new Thread(new NotifyThread(lock), "notifyThread");
    6. waitThread.start();
    7. Thread.sleep(1000);
    8. notifyThread.start();
    9. }
    10. }

    控制台显示

    1. waitThread开始进入同步代码块区域
    2. notifyThread开始进入同步代码块区域
    3. notifyThread业务处理开始
    4. notifyThread业务处理结束
    5. notifyThread准备离开同步代码块区域
    6. waitThread准备离开同步代码块区域
    7. notifyThread退出同步代码块后续操作

    2.7、notifyAll() 与wait() 

            Object notifyAll() 方法用于唤醒在该对象上等待的所有线程。

    等待线程

    1. public class WaitThread implements Runnable{
    2. Object lock;
    3. public WaitThread(Object lock){
    4. this.lock = lock;
    5. }
    6. public void run() {
    7. String threadName = Thread.currentThread().getName();
    8. synchronized (lock){
    9. System.out.println(threadName + "开始进入同步代码块区域");
    10. try {
    11. lock.wait();
    12. } catch (InterruptedException e) {
    13. e.printStackTrace();
    14. }
    15. System.out.println(threadName + "准备离开同步代码块区域");
    16. }
    17. }
    18. }

    唤醒线程

    1. public class NotifyThread implements Runnable{
    2. Object lock;
    3. public NotifyThread(Object lock){
    4. this.lock = lock;
    5. }
    6. public void run() {
    7. String threadName = Thread.currentThread().getName();
    8. synchronized (lock){
    9. System.out.println(threadName + "开始进入同步代码块区域");
    10. lock.notifyAll();
    11. try {
    12. System.out.println(threadName + "业务处理开始");
    13. // 暂停 2s 表示业务处理
    14. Thread.sleep(2000);
    15. System.out.println(threadName + "业务处理结束");
    16. } catch (InterruptedException e) {
    17. e.printStackTrace();
    18. }
    19. System.out.println(threadName + "准备离开同步代码块区域");
    20. //lock.notifyAll();放在这一行唤醒,效果一样
    21. }
    22. try {
    23. Thread.sleep(5000);
    24. } catch (InterruptedException e) {
    25. e.printStackTrace();
    26. }
    27. System.out.println(threadName + "退出同步代码块后续操作");
    28. }
    29. }

    主程序

    1. public class Test2 {
    2. public static void main(String[] args) throws InterruptedException {
    3. Object lock = new Object();
    4. Thread waitThread = new Thread(new WaitThread(lock), "waitThread");
    5. Thread waitThread2 = new Thread(new WaitThread(lock), "waitThread2");
    6. Thread notifyThread = new Thread(new NotifyThread(lock), "notifyThread");
    7. waitThread.start();
    8. waitThread2.start();
    9. Thread.sleep(1000);
    10. notifyThread.start();
    11. }
    12. }

    控制台显示

    1. waitThread开始进入同步代码块区域
    2. waitThread2开始进入同步代码块区域
    3. notifyThread开始进入同步代码块区域
    4. notifyThread业务处理开始
    5. notifyThread业务处理结束
    6. notifyThread准备离开同步代码块区域
    7. waitThread准备离开同步代码块区域
    8. waitThread2准备离开同步代码块区域
    9. notifyThread退出同步代码块后续操作

    2.8、toString() 

            Object toString() 方法用于返回对象的字符串表示形式

    1. public class Main {
    2. public static void main(String[] args) {
    3. // toString() with Object
    4. Object obj1 = new Object();
    5. System.out.println(obj1.toString());
    6. Object obj2 = new Object();
    7. System.out.println(obj2.toString());
    8. Object obj3 = new Object();
    9. System.out.println(obj3.toString());
    10. }
    11. }

    控制台显示

    1. java.lang.Object@3d012ddd
    2. java.lang.Object@626b2d4a
    3. java.lang.Object@5e91993f

  • 相关阅读:
    docker离线搭建仓库
    Linux学习 - vi/vim编辑器
    c# -- 内存讲解和类型
    网站设计源代码制作素材成品(风景 6页)___内嵌式
    2022谷粒商城学习笔记(十九)认证服务整合短信验证码和OAuth2第三方社交登录
    《入门docker,这一篇就够了》
    python
    安装redis 集群
    从零开始的python生活02
    企业为什么难创新?5个常见的创新障碍
  • 原文地址:https://blog.csdn.net/u012965203/article/details/127688940