认识 java.lang.Object
来源:互联网 发布:淘宝什么时候自动评价 编辑:程序博客网 时间:2024/05/22 03:50
本文版权归Stephen Wang所有。可以任意复制、转载,但请注明出处。
参考下JDK文档,你会发现java.lang.Object会提供以下一些方法:
protected Object clone();
protected void finalize();
public boolean equals(Object obj);
public Class getClass();
public int hashCode();
public void notify();
public void notifyAll();
public String toString();
public void wait();
public void wait(lone timeout);
public void wait(long timeout, int nanos);
JAVA当中,所有类都直接或者简介继承至Object。不管是我们自定义的类,还是jdk提供的类,都会拥有上面的方法供我们使用。Object类为我们提供了这么多方法,我吗如何使用它们呢?
首先看下clone方法,很奇怪吧,这个方法被声明成了protected。这意味着,除了Object的子类外,外部类无法直接调用克隆方法生成对象的镜像。Object的子类可以访问该方法。但是,JDK要求,通过这个方法返回的对象,需要满足以下条件:
x.clone() != x 返回true
x.clone().getClass() == x.getClass() 返回true
x.clone().equals(x) 返回ture。
同时,如果想将这个方法暴露给外部,需要实现Cloneable接口。并让这个接口返回的对象,满足上面的三个条件。说白了,就是深拷贝,呵呵。老外描述问题都比较严格,通过正规化的公式来表达。
如果继承层次比较深,实现Cloneable接口时,要求父类也必须实现Cloneable对象。一般在在子类的实现的时候,处理当前类层次的clone时,需要调用super.clone(),来返回父类的副本。
finalize方法也被声明为protected,目的无非是想不想让用户主动调用。一般,如果类持有I/O等宝贵资源时,为保证资源及时回收,需要实现这个方法进行释放。这个方法会在对象被垃圾回收的时候由虚拟机自动调用。
下面说说wait和notify,wait有3个,notify有两个。每个对象在创建时,都默认有一个对象锁。用synchronized修饰的方法,在方法执行前,会尝试去获得这个对象锁(注意,是对象锁。还有一个类锁,该关键字修饰静态方法时,就尝试去获得类锁。),如果有人占用了, 那么本线程就阻塞,直到锁可用为止。这样就可以保护只有一个线程可以进入该方法。
这是一种简单的互斥同步。还有一种情况是,线程等待某个条件的发生。每个对象锁都有一个默认的条件。还是举个例子来说,比如有一个house对象,go方法是出去玩,但只有在门开启的时候,才可以执行。而开启门的条件是父母下班回家,姥姥买菜回家等。
class house {
private boolean opened = false;
public void go() {
if(!opened) {
wait();
}
System.out.println("go out play.");
}
public void open() {
System.out.println("I am back, I am opening the door.");
opened = true;
notify();
}
}
notify只是随机唤醒一个等待的线程。nitifyAll唤醒所有等待的线程。唤醒的线程不一定会执行,需要虚拟机调度后才执行。如果有多个小孩都在等待开门,就用notifyAll来通知大家把。
getClass 返回类型。略。
hashCode, equals 请自行搜索iteye吧,刚搜索了下,文章挺多。我就重复了。
本文版权归Stephen Wang所有。可以任意复制、转载,但请注明出处。
参考下JDK文档,你会发现java.lang.Object会提供以下一些方法:
protected Object clone();
protected void finalize();
public boolean equals(Object obj);
public Class getClass();
public int hashCode();
public void notify();
public void notifyAll();
public String toString();
public void wait();
public void wait(lone timeout);
public void wait(long timeout, int nanos);
JAVA当中,所有类都直接或者简介继承至Object。不管是我们自定义的类,还是jdk提供的类,都会拥有上面的方法供我们使用。Object类为我们提供了这么多方法,我吗如何使用它们呢?
首先看下clone方法,很奇怪吧,这个方法被声明成了protected。这意味着,除了Object的子类外,外部类无法直接调用克隆方法生成对象的镜像。Object的子类可以访问该方法。但是,JDK要求,通过这个方法返回的对象,需要满足以下条件:
x.clone() != x 返回true
x.clone().getClass() == x.getClass() 返回true
x.clone().equals(x) 返回ture。
同时,如果想将这个方法暴露给外部,需要实现Cloneable接口。并让这个接口返回的对象,满足上面的三个条件。说白了,就是深拷贝,呵呵。老外描述问题都比较严格,通过正规化的公式来表达。
如果继承层次比较深,实现Cloneable接口时,要求父类也必须实现Cloneable对象。一般在在子类的实现的时候,处理当前类层次的clone时,需要调用super.clone(),来返回父类的副本。
finalize方法也被声明为protected,目的无非是想不想让用户主动调用。一般,如果类持有I/O等宝贵资源时,为保证资源及时回收,需要实现这个方法进行释放。这个方法会在对象被垃圾回收的时候由虚拟机自动调用。
下面说说wait和notify,wait有3个,notify有两个。每个对象在创建时,都默认有一个对象锁。用synchronized修饰的方法,在方法执行前,会尝试去获得这个对象锁(注意,是对象锁。还有一个类锁,该关键字修饰静态方法时,就尝试去获得类锁。),如果有人占用了, 那么本线程就阻塞,直到锁可用为止。这样就可以保护只有一个线程可以进入该方法。
这是一种简单的互斥同步。还有一种情况是,线程等待某个条件的发生。每个对象锁都有一个默认的条件。还是举个例子来说,比如有一个house对象,go方法是出去玩,但只有在门开启的时候,才可以执行。而开启门的条件是父母下班回家,姥姥买菜回家等。
class house {
private boolean opened = false;
public void go() {
if(!opened) {
wait();
}
System.out.println("go out play.");
}
public void open() {
System.out.println("I am back, I am opening the door.");
opened = true;
notify();
}
}
notify只是随机唤醒一个等待的线程。nitifyAll唤醒所有等待的线程。唤醒的线程不一定会执行,需要虚拟机调度后才执行。如果有多个小孩都在等待开门,就用notifyAll来通知大家把。
getClass 返回类型。略。
hashCode, equals 请自行搜索iteye吧,刚搜索了下,文章挺多。我就重复了。
本文版权归Stephen Wang所有。可以任意复制、转载,但请注明出处。
- 认识 java.lang.Object
- java.lang.Object类
- java.lang.Object类
- java.lang.Object类
- java.lang.Object.clone()
- java.lang.Object学习
- 01 java.lang.Object
- 浅谈java.lang.object
- Java.lang.Object 类
- java.lang.Object
- java.lang.Object总结
- java.lang.Object
- java.lang.Object
- java.lang.object
- java/lang/NoClassDefFoundError: java/lang/Object
- java/lang/NoClassDefFoundError: java/lang/Object
- java/lang/NoClassDefFoundError: java/lang/Object
- 认识java.lang.Class类
- C#解析xml(获取指定节点值)
- 笔记:Linux Shell (五):标准输入输出重定向
- mysql+hibernate数据库查询问题
- API问题 求教
- Android TextView的各种属性
- 认识 java.lang.Object
- 基础控件ListView
- The server does not support version 3.0 of the J2EE Web module specification
- 【jiasuba】系统的那些经常被大家忽视的注册表常用键值的意思
- 生成release版本的Android系统
- Ubuntu12.04下FSL的安装(待完善)
- mysql索引列不能改为text属性
- xml文件的注意事项
- 关于ListView的Adapter,解决ListView滚动后内容重复的问题