JavaBean是通过反射机制来完成的,写JavaBean和写普通的类的目的是一样的,都是为了实例化该类的对象,然后利用这个对象,就可以使用这个类了。
JavaBean和普通的类区别如下:
|- 首先,要有一个无参的构造方法(但不是必须的)。
|- 属性使用private修饰。
|- 存在Setter和Getter方法。
既然JavaBean通过反射来完成,那么JavaBean实例化的方式,也就同样是通过反射来完成。回想一下,使用反射机制,来实例化一个类的对象的步骤:
|- 首先,使用Class.forName() 方法将.class文件加载入内存中,并取得一个Class类型的对象c。当然若内存中已经存在了该字节码文件,则不会再重新加载。
|- 然后,调用对象 c 的newInstance() 方法,实例化出一个其所代表的类的对象。
但是,众所周知,实例化对象的时候,在扫面完类中所有的字段和实例块后,就会调用构造方法,那么再上述过程中,调用的是哪个构造方法呢? 很显然,调用的是无参的那个构造方法。
至此,答案就很显然了,若您是通过类似于上述步骤,来实例化JavaBean的时候,就必须提供一个无参的构造方法。不然运行时就会出错。 若您是通过如下步骤,则就不需要提供无参的构造方法了:
假设咱们有如下的一个PersonBean。[code=java]package org.cxy.vo;
public class Person {
private String name;
private String sex;
public Person(String name,String sex){
this.name = name;
this.sex = sex;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String toString(){
return "姓名:"+this.name+",性别:"+this.sex;
}
}[/code]然后咱们使用如下代码进行反射操作:[code=java]package org.cxy.vo;
import java.lang.reflect.*;
public class Demo {
public static void main(String[] args)throws Exception{
Class<erson> p = (Class<erson>)Class.forName("org.cxy.vo.Person");
Constructor<erson> con = p.getConstructor(String.class,String.class);
Person inst = con.newInstance("张三","男");
System.out.println(inst);
}
}[/code]这样一来,程序照样可以运行正确。同时Person类中也不存在无参的构造方法。
总之,为了养成良好的习惯,您应该为每一个类都写上无参的构造方法。
等到您学习 Java Web的时候,会接触到真正的JavaBean以及标签编程等技术,那些技术里面到处都充斥着反射机制,所以,理解反射技术的原理,是必须的。
|