• 关于JAVA学习_Object类


    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的区别

        假设现在有一个Employee对象,Employee tobby =new Employee(“CMTobby”,5000)
        通常我们会有这样的赋值Employee cindyelf=tobby,这个时候只是简单了copy了一下reference,cindyelf和tobby都指向内存中同一个object,
        这样cindyelf或者tobby的一个操作都可能影响到对方。打个比方,如果我们通过cindyelf.raiseSalary()方法改变了salary域的值,那么tobby通过
        getSalary()方法得到的就是修改之后的salary域的值,显然这不是我们愿意看到的。我们希望得到tobby的一个精确拷贝,同时两者互不影响,这时候
        我们就可以使用Clone来满足我们的需求。Employee cindy=tobby.clone(),这时会生成一个新的Employee对象,并且和tobby具有相同的属性值和方法。

    1.2、clone方法的保护机制

        在Object中Clone()是被声明为protected的,这样做是有一定的道理的,以Employee。
        类为例,通过声明为protected,就可以保证只有Employee类里面才能“克隆”Employee对象

    1.3、clone方法的使用

        Clone()方法的使用比较简单,注意如下几点即可:
             什么时候使用shallow Clone,什么时候使用deep Clone,这个主要看具体对象的域是什么性质的,基本型别还是reference variable
            调用Clone()方法的对象所属的类(Class)必须implements Clonable接口,否则在调用Clone方法的时候会抛出CloneNotSupportedException
    更加详细的解释:点击查看

    二、toString()方法

    Object 类的 toString 方法返回一个字符串,该字符串由类名(对象是该类的一个实例)、at 标记符“@”和此对象哈希码的无符号十六进制表示组成
    该方法用得比较多,一般子类都有覆盖。

        例子:
    复制代码
    <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>
    复制代码
            结果:java.lang.Object@7852e922

    三、getClass()方法

     返回次Object的运行时类类型。
    不可重写,要调用的话,一般和getName()联合使用,如getClass().getName();

    四、finalize()方法


    该方法用于释放资源。因为无法确定该方法什么时候被调用,很少使用。

    Java允许在类中定义一个名为finalize()的方法。它的工作原理是:一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其finalize()方法。并且在下一次垃圾回收动作发生时,才会真正回收对象占用的内存。

    关于垃圾回收,有三点需要记住:

      1、对象可能不被垃圾回收。只要程序没有濒临存储空间用完的那一刻,对象占用的空间就总也得不到释放。

      2、垃圾回收并不等于“析构”。

      3、垃圾回收只与内存有关。使用垃圾回收的唯一原因是为了回收程序不再使用的内存。

    finalize()的用途:

      无论对象是如何创建的,垃圾回收器都会负责释放对象占据的所有内存。这就将对finalize()的需求限制到一种特殊情况,即通过某种创建对象方式以外的方式为对象分配了存储空间。

      不过这种情况一般发生在使用“本地方法”的情况下,本地方法是一种在Java中调用非Java代码的方式。

    五、equals()方法

    Object中的equals方法是直接判断this和obj本身的值是否相等,即用来判断调用equals的对象和形参obj所引用的对象是否是同一对象,
    所谓同一对象就是指内存中同一块存储单元,如果this和obj指向的hi同一块内存对象,则返回true,如果this和obj指向的不是同一块内存,则返回false。
    注意:即便是内容完全相等的两块不同的内存对象,也返回false。

              如果是同一块内存,则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

  • 相关阅读:
    Etherpad Lite v1 — LinuxTOY
    linux 命令
    Useful tmux Commands
    利用统计进行中文分词与词性分析
    RemoteBox : Screenshots Screenshots Various screenshots of RemoteBox under different operating systems including Linux, MacOS X, Solaris, NetBSD, FreeBSD and OpenBSD. Do you have a screenshot of RemoteBox running on a distro or operating system
    EF架构~一个规范,两个实现
    EF架构~一个规范,两个实现(续)~性能可以接受的批量增删改操作
    微软自己写的~测试远程数据库是否工作正常
    编译器错误~System.Data.Objects.DataClasses.EntityObject在未被引用的程序集中定义
    说说Entity Frameworks
  • 原文地址:https://www.cnblogs.com/yumu77/p/13746532.html
Copyright © 2020-2023  润新知