动态获取信息以及调用类中的方法和属性的功能成为java反射机制,说的通俗一点就是先通过反射来获取字节码文件,再通过字节码来进行对象的创建。
反射写的代码:
public static void main(String[] args) throws ClassNotFoundException, IOException, InstantiationException, IllegalAccessException {
//将配置文件封装成br对象
BufferedReader br = new BufferedReader(new FileReader("config2.properties"));
//获取字节码文件
Class clazz = Class.forName(br.readLine());
//用字节码文件来获取Apple对象
Fruit f = (Fruit) clazz.newInstance();
f.squeeze();
}
}
interface Fruit2{
public void squeeze();
}
class Apple2 implements Fruit{
public void squeeze() {
System.out.println("苹果汁");
}
}
class Banana2 implements Fruit{
public void squeeze() {
System.out.println("香蕉酱");
}
}
class Juicer2{
public void run(Fruit f) {
f.squeeze();
}
}
配置文件为:com.xy.test16.Apple2
通过配置文件来修改调用的类的好处是不用在源码中改来改去。没学反射之前要喝到不同的果汁就要修改源码,学了反射后用配置文件修改配置文件包后的类名:
public static void main(String[] args) {
// TODO Auto-generated method stub
Juicer j = new Juicer();
//j.run(new Apple());
j.run(new Banana());
}
}
//class Fruit{
// public void squeeze() {
//System.out.println("汁");
// }
//}
interface Fruit{
public void squeeze();
}
class Apple implements Fruit{
public void squeeze() {
System.out.println("苹果汁");
}
}
class Banana implements Fruit{
public void squeeze() {
System.out.println("香蕉酱");
}
}
class Juicer{
public void run(Fruit f) {
f.squeeze();
}
}
这里面还用到了多态,父类引用指向子类使代码复用性提高。
总结:有的程序是不让你修改源码的,所以只有通过修改配置文件的修改来创建不同的对象。