×

java反射机制的作用 java java反射

java反射机制的作用(java反射机制有什么用)

admin admin 发表于2022-09-04 06:27:05 浏览98 评论0

抢沙发发表评论

本文目录

java反射机制有什么用


如果你是方法,快递员是虚拟机。快递员通过地址查地图找你的叫反射调用。直接去找你的叫直接调用。反射很多地方在用,代码编辑器智能提示就是反射的例子。

什么是JAVA的反射机制有什么作用


现在学习Java的平台有很多,B站或者是腾讯课堂都是可以的,我们在B站分享了很多经典的Java视频教程,都是开源的,你可以去看看。


java中的反射机制是什么,有什么作用啊


Method类中的方法的使用(含代码和注释):

getMethods()获得本类及父类中的public权限修饰**符方法
getDeclaredMethods()专门获得调用该方法的对象的本类中的所有方法包括private权限修饰符**的方法
getDeclaredMethod(String name,class《?》...parameterTypes)
第一个参数:方法的名称
第二个参数:可变长度,写你要查找的那个方法的参数类型列表.class
getParameterCount()得到方法的参数个数123456
package LessonForReflection03;import java.lang.reflect.Method;import java.lang.reflect.Modifier;abstract class Card{
private void creatRandomNumbers(int count)//private关键字
{
}
public void getFullCardsNumbers(String random, String pre_numbers)
{
}
public static void getUserInfor()
{
}
public abstract void getUserInfor(String tel);
public abstract void getUserInfor(int sal1, int sal2) throws ArrayIndexOutOfBoundsException,ArithmeticException;}public class MethodInforGetter {
public static void main(String args) 
{
Class《?》 c1 = Card.class;
System.out.println(“-------------------------“);
Method m1 = c1.getMethods();//getMethods()获得本类及父类中的public方法!
for (Method m:m1)
{
System.out.println(m);
}
System.out.println(“-------------------------“);
Method m2 = c1.getDeclaredMethods();//getDeclaredMethods()专门获得本类中的所有方法包括private!
for (Method m:m2)
{
System.out.println(m);
}
System.out.println(“-------------------------“);
/*
*getDeclaredMethod(String name,class《?》...parameterTypes)
*第一个参数:方法的名称
*第二个参数:可变长度,写你要查找的那个方法的参数类型列表
*
* getParameterCount()得到方法的参数个数
*/
try 
{
Method m3 = c1.getDeclaredMethod(“getUserInfor“);
System.out.println(m3);
//getParameterCount()方法,获得方法参数个数
System.out.println(m3.getParameterCount());
System.out.println(Modifier.toString(m3.getModifiers()));//获得方法修饰符
System.out.println(m3.getReturnType());
System.out.println(“-------------------------“);
Method m4 = c1.getDeclaredMethod(“getUserInfor“, int.class,int.class);
//getExceptionTypes()可以获得初始化当前Method对象的给Class对象初始化的那个类的那个指定方法抛出的异常类型
Class《?》 exception = m4.getExceptionTypes();
for (Class《?》 e:exception)
{
System.out.println(e);
}
} catch (NoSuchMethodException | SecurityException e) 
{
e.printStackTrace();
}
}}12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788-JAVA

Constructor类中的方法的使用www.xiaoyuani.com(含代码和注释):

java.lang.reflect.Constructor:
Constructor getConstructor()获得本类里的public权限修饰符构造函数,不能获取父类的!
Constructor getDeclaredConstructor()获得本类中的所以构造函数!
Constructor《T》 getConstructor(Class...parameterType)用参数决定获得本类中的某个的构造方法,只能获得public的
Constructor《T》 getDeclaredConstructor(Class...parameterType)用参数决定获得本类中的某个构造方法
附:
JDK8.0之后新增的类:
Executable:
它是Method和Constructor的父类
常用方法:
getParameter()获得类中方法参数
getExceptionTypes()获得类中某个方法抛出异常类型
getMoidfiers()获得方法权限修饰符
Parameter:
封装并代表了参数实例123456789101112131415
package LessonForReflection03;import java.lang.reflect.Constructor;import java.lang.reflect.Modifier;import java.lang.reflect.Parameter;/*
* java.lang.reflect.Constructor
*
* Constructor getConstructor();获得本类里的public权限修饰符构造函数,不能获取父类的
*  Constructor getDeclaredConstructor();得本类里的全部构造
*
*  Constructor《T》 getConstructor(Class...parameterType);用参数决定获得哪个构造方法
*  Constructor《T》 getDeclaredConstructor(Class...parameterType);
*
*/public class ConstructorInforGetter {
public static void main(String args) 
{
System.out.println(“获得Cricle本类里的public权限修饰符构造函数,不能获取父类的Constructor getConstructor()“);
System.out.println(“子类继承不了父类中的构造方法和private“);
//Constructor getConstructor()获得Cricle本类里的public权限修饰符构造函数,不能获取父类的
//子类继承不了父类中的构造方法和private
Class《Circle》 c1 = Circle.class;
Constructor《?》 cons1 = c1.getConstructors();
for (Constructor《?》 cons:cons1)
{
System.out.println(cons);
//System.out.println(cons.getName());
}
System.out.println(“-----------------------“);
System.out.println(“方法获得本类中的所有构造函数getDeclaredConstructor()“);
Constructor《?》 cons2 = c1.getDeclaredConstructors();
for (Constructor《?》 cons:cons2)
{
System.out.println(cons);
}
System.out.println(“-----------------------“);
try 
{
System.out.println(“方法用参数指定获得本类!构造方法,只能获取public的Constructor《T》 getConstructor(Class...parameterType)“);
Constructor《?》 cons3 = c1.getConstructor(int.class);
System.out.println(Modifier.toString(cons3.getModifiers()));
System.out.println(cons3);
System.out.println(“-----------------------“);
System.out.println(“方法用参数指定获得本类!构造方法任何权限修饰符的都可以获得Constructor《T》 getDeclaredConstructor(Class...parameterType)“);
Constructor《?》 cons4 = c1.getDeclaredConstructor(String.class);
System.out.println(cons4);
System.out.println(“-----------------------“);
/*
* JDK8.0之后新增的类
* Executable:
* 是Method和Constructor的父类
* 方法:
* getParameter();
* getExceptionTypes();
* getModifiers();
*          getTypeParameters();
*
*  Parameter:
*  封装并代表了参数实例
*/
System.out.println(“获取类中方法的参数getParameters()“);
Constructor《?》 cons5 = c1.getDeclaredConstructor(int.class,String.class);
Parameter p1 = cons5.getParameters();
for (Parameter p:p1)
{
System.out.println(p);
}
} catch (NoSuchMethodException | SecurityException e) 
{
e.printStackTrace();
}
}}123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687-java

代码中提到的Circle类和Shape类二者为继承关系:

package LessonForReflection03;public class Circle extends Shape{
private int r;
private String color;
public Circle(int r, String color) 
{
super();
this.r = r;
this.color = color;
}
public Circle(int r) 
{
super();
this.r = r;
}
protected Circle(String color) 
{
super();
this.color = color;
}
Circle()
{
super();
}}12345678910111213141516171819202122232425262728293031
package LessonForReflection03;public class Shape {
private int per;
public Shape(int per) 
{
super();
this.per = per;
}
public Shape() 
{
super();
}}1234567891011121314151617-JAVA

部分文字来源于:
咕嘟咖啡杨海滨老师 — 《java编程语言高级特性》
轻量化研习Java相关技术倡导者
“爱码学院”联合创始人自适应教学理念提出者践行者;多年开发及项目管理经历;出版《JavaEE企业级应用与开发》一书;10余年高校项目实践毕设指导经验;企业软培经验丰富-java


java反射机制的作用请举例说明


比较全的解释了:JAVA反射机制
JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。
Java反射机制主要提供了以下功能: 在运行时判断任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判断任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。
1. 得到某个对象的属性
1 public Object getProperty(Object owner, String fieldName) throws Exception {
2 Class ownerClass = owner.getClass();
3
4 Field field = ownerClass.getField(fieldName);
5
6 Object property = field.get(owner);
7
8 return property;
9 }
Class ownerClass = owner.getClass():得到该对象的Class。
Field field = ownerClass.getField(fieldName):通过Class得到类声明的属性。
Object property = field.get(owner):通过对象得到该属性的实例,如果这个属性是非公有的,这里会报IllegalAccessException。
2. 得到某个类的静态属性
1 public Object getStaticProperty(String className, String fieldName)
2 throws Exception {
3 Class ownerClass = Class.forName(className);
4
5 Field field = ownerClass.getField(fieldName);
6
7 Object property = field.get(ownerClass);
8
9 return property;
10 }
Class ownerClass = Class.forName(className) :首先得到这个类的Class。
Field field = ownerClass.getField(fieldName):和上面一样,通过Class得到类声明的属性。
Object property = field.get(ownerClass) :这里和上面有些不同,因为该属性是静态的,所以直接从类的Class里取。
3. 执行某对象的方法
1 public Object invokeMethod(Object owner, String methodName, Object args) throws Exception {
2
3 Class ownerClass = owner.getClass();
4
5 Class argsClass = new Class[args.length];
6
7 for (int i = 0, j = args.length; i 《 j; i++) {
8 argsClass[i] = args[i].getClass();
9 }
10
11 Method method = ownerClass.getMethod(methodName, argsClass);
12
13 return method.invoke(owner, args);
14 }
Class owner_class = owner.getClass() :首先还是必须得到这个对象的Class。
5~9行:配置参数的Class数组,作为寻找Method的条件。
Method method = ownerClass.getMethod(methodName, argsClass):通过Method名和参数的Class数组得到要执行的Method。
method.invoke(owner, args):执行该Method,invoke方法的参数是执行这个方法的对象,和参数数组。返回值是Object,也既是该方法的返回值。
4. 执行某个类的静态方法
1 public Object invokeStaticMethod(String className, String methodName,
2 Object args) throws Exception {
3 Class ownerClass = Class.forName(className);
4
5 Class argsClass = new Class[args.length];
6
7 for (int i = 0, j = args.length; i 《 j; i++) {
8 argsClass[i] = args[i].getClass();
9 }
10
11 Method method = ownerClass.getMethod(methodName, argsClass);
12
13 return method.invoke(null, args);
14 }
基本的原理和实例3相同,不同点是最后一行,invoke的一个参数是null,因为这是静态方法,不需要借助实例运行。
5. 新建实例
1
2 public Object newInstance(String className, Object args) throws Exception {
3 Class newoneClass = Class.forName(className);
4
5 Class argsClass = new Class[args.length];
6
7 for (int i = 0, j = args.length; i 《 j; i++) {
8 argsClass[i] = args[i].getClass();
9 }
10
11 Constructor cons = newoneClass.getConstructor(argsClass);
12
13 return cons.newInstance(args);
14
15 }
这里说的方法是执行带参数的构造函数来新建实例的方法。如果不需要参数,可以直接使用newoneClass.newInstance()来实现。
Class newoneClass = Class.forName(className):第一步,得到要构造的实例的Class。
第5~第9行:得到参数的Class数组。
Constructor cons = newoneClass.getConstructor(argsClass):得到构造子。
cons.newInstance(args):新建实例。
6. 判断是否为某个类的实例
1 public boolean isInstance(Object obj, Class cls) {
2 return cls.isInstance(obj);
3 }
7. 得到数组中的某个元素
1 public Object getByArray(Object array, int index) {
2 return Array.get(array,index);
3 }
-JAVA

java中的反射可以做什么


Java反射机制主要提供了以下功能:
在运行时判断任意一个对象所属的类;
在运行时构造任意一个类的对象;
在运行时判断任意一个类所具有的成员变量和方法;
在运行时调用任意一个对象的方法;生成动态代理。
JAVA有着一个非常突出的动态相关机制:Reflection。
这个字的意思是“反射、映象、倒影”,用在Java身上指的是我们可以于运行时加载、探知、使用编译期间完全未知的classes。换句话说,Java程序可以加载一个运行时才得知名称的class,获悉其完整构造(但不包括methods定义),并生成其对象实体、或对其fields设值、或唤起其methods。这种“看透class”的能力(the ability of the program to examine itself)被称为introspection(内省、内观、反省)。Reflection和introspection是常被并提的两个术语。
-java

java的反射技术有什么用


一、反射的概述

JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。
要想解剖一个类,必须先要获取到该类的字节码文件对象。而解剖使用的就是Class类中的方法.所以先要获取到每一个字节码文件对应的Class类型的对象.-JAVA

以上的总结就是什么是反射
反射就是把java类中的各种成分映射成一个个的Java对象
例如:一个类有:成员变量、方法、构造方法、包等等信息,利用反射技术可以对一个类进行解剖,把个个组成部分映射成一个个对象。(其实:一个类中这些成员方法、构造方法、在加入类中都有一个类来描述)
如图是类的正常加载过程:反射的原理在与class对象。
熟悉一下加载的时候:Class对象的由来是将class文件读入内存,并为之创建一个Class对象。-java

二、Java中为什么需要反射?反射要解决什么问题?

Java中编译类型有两种:

  • 静态编译:在编译时确定类型,绑定对象即通过。

  • 动态编译:运行时确定类型,绑定对象。动态编译最大限度地发挥了Java的灵活性,体现了多态的应用,可以减低类之间的耦合性。

  • Java反射是Java被视为动态(或准动态)语言的一个关键性质。这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息,包括其modifiers(诸如public、static等)、superclass(例如Object)、实现之interfaces(例如Cloneable),也包括fields和methods的所有信息,并可于运行时改变fields内容或唤起methods。-JAVA

    Reflection可以在运行时加载、探知、使用编译期间完全未知的classes。即Java程序可以加载一个运行时才得知名称的class,获取其完整构造,并生成其对象实体、或对其fields设值、或唤起其methods。-java

    反射(reflection)允许静态语言在运行时(runtime)检查、修改程序的结构与行为。
    在静态语言中,使用一个变量时,必须知道它的类型。在Java中,变量的类型信息在编译时都保存到了class文件中,这样在运行时才能保证准确无误;换句话说,程序在运行时的行为都是固定的。如果想在运行时改变,就需要反射这东西了。-JAVA

    实现Java反射机制的类都位于java.lang.reflect包中:

  • Class类:代表一个类

  • Field类:代表类的成员变量(类的属性)

  • Method类:代表类的方法

  • Constructor类:代表类的构造方法

  • Array类:提供了动态创建数组,以及访问数组的元素的静态方法

  • 一句话概括就是使用反射可以赋予jvm动态编译的能力,否则类的元数据信息只能用静态编译的方式实现,例如热加载,Tomcat的classloader等等都没法支持。

    三、使用

    1、获取Class对象的三种方式

    1.1 Object ——》 getClass();
    1.2 任何数据类型(包括基本数据类型)都有一个“静态”的class属性
    1.3 通过Class类的静态方法:forName(String  className)(常用)-java

    请点击输入图片描述

    希望对您有所帮助!~


java的反射机制用处在哪


java的反射机制就是增加程序的灵活性,避免将程序写死到代码里,典型应用是Spring
例如: 实例化一个 person()对象, 不使用反射, new person(); 如果想变成 实例化 其他类, 那么必须修改源代码,并重新编译。
使用反射: class.forName(“person“).newInstance(); 而且这个类描述可以写到配置文件中,如 **.xml, 这样如果想实例化其他类,只要修改配置文件的“类描述“就可以了,不需要重新修改代码并编译。
-JAVA

java中的反射机制是什么有什么作用呢求解,谢谢


Java反射机制详解

1. 反射机制是什么

反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。-java

2. 反射机制能做什么

反射机制主要提供了以下功能: 

  • 在运行时判断任意一个对象所属的类;

  • 在运行时构造任意一个类的对象;

  • 在运行时判断任意一个类所具有的成员变量和方法;

  • 在运行时调用任意一个对象的方法;

  • 生成动态代理。

3. 反射机制的相关API

通过一个对象获得完整的包名和类名

package net.xsoftlab.baike;
public class TestReflect {
    public static void main(String args) throws Exception {
        TestReflect testReflect = new TestReflect();
        System.out.println(testReflect.getClass().getName());
        // 结果 net.xsoftlab.baike.TestReflect
    }
}

实例化Class类对象-JAVA

package net.xsoftlab.baike;
public class TestReflect {
    public static void main(String args) throws Exception {
        Class《?》 class1 = null;
        Class《?》 class2 = null;
        Class《?》 class3 = null;
        // 一般采用这种形式
        class1 = Class.forName(“net.xsoftlab.baike.TestReflect“);
        class2 = new TestReflect().getClass();
        class3 = TestReflect.class;
        System.out.println(“类名称   “ + class1.getName());
        System.out.println(“类名称   “ + class2.getName());
        System.out.println(“类名称   “ + class3.getName());
    }
}

获取一个对象的父类与实现的接口-java

package net.xsoftlab.baike;
import java.io.Serializable;
public class TestReflect implements Serializable {
    private static final long serialVersionUID = -2862585049955236662L;
    public static void main(String args) throws Exception {
        Class《?》 clazz = Class.forName(“net.xsoftlab.baike.TestReflect“);
        // 取得父类
        Class《?》 parentClass = clazz.getSuperclass();
        System.out.println(“clazz的父类为:“ + parentClass.getName());
        // clazz的父类为: java.lang.Object
        // 获取所有的接口
        Class《?》 intes = clazz.getInterfaces();
        System.out.println(“clazz实现的接口有:“);
        for (int i = 0; i 《 intes.length; i++) {
            System.out.println((i + 1) + “:“ + intes[i].getName());
        }
        // clazz实现的接口有:
        // 1:java.io.Serializable
    }
}

获取某个类中的全部构造函数 - 详见下例-JAVA

通过反射机制实例化一个类的对象

package net.xsoftlab.baike;
import java.lang.reflect.Constructor;
public class TestReflect {
    public static void main(String args) throws Exception {
        Class《?》 class1 = null;
        class1 = Class.forName(“net.xsoftlab.baike.User“);
        // 第一种方法,实例化默认构造方法,调用set赋值
        User user = (User) class1.newInstance();
        user.setAge(20);
        user.setName(“Rollen“);
        System.out.println(user);
        // 结果 User [age=20, name=Rollen]
        // 第二种方法 取得全部的构造函数 使用构造函数赋值
        Constructor《?》 cons = class1.getConstructors();
        // 查看每个构造方法需要的参数
        for (int i = 0; i 《 cons.length; i++) {
            Class《?》 clazzs = cons[i].getParameterTypes();
            System.out.print(“cons[“ + i + “] (“);
            for (int j = 0; j 《 clazzs.length; j++) {
                if (j == clazzs.length - 1)
                    System.out.print(clazzs[j].getName());
                else
                    System.out.print(clazzs[j].getName() + “,“);
            }
            System.out.println(“)“);
        }
        // 结果
        // cons (java.lang.String)
        // cons (int,java.lang.String)
        // cons ()
        user = (User) cons.newInstance(“Rollen“);
        System.out.println(user);
        // 结果 User [age=0, name=Rollen]
        user = (User) cons.newInstance(20, “Rollen“);
        System.out.println(user);
        // 结果 User [age=20, name=Rollen]
    }
}
class User {
    private int age;
    private String name;
    public User() {
        super();
    }
    public User(String name) {
        super();
        this.name = name;
    }
    public User(int age, String name) {
        super();
        this.age = age;
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    @Override
    public String toString() {
        return “User [age=“ + age + “, name=“ + name + “]“;
    }
}

获取某个类的全部属性-java

package net.xsoftlab.baike;
import java.io.Serializable;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
public class TestReflect implements Serializable {
    private static final long serialVersionUID = -2862585049955236662L;
    public static void main(String args) throws Exception {
        Class《?》 clazz = Class.forName(“net.xsoftlab.baike.TestReflect“);
        System.out.println(“===============本类属性===============“);
        // 取得本类的全部属性
        Field field = clazz.getDeclaredFields();
        for (int i = 0; i 《 field.length; i++) {
            // 权限修饰符
            int mo = field[i].getModifiers();
            String priv = Modifier.toString(mo);
            // 属性类型
            Class《?》 type = field[i].getType();
            System.out.println(priv + “ “ + type.getName() + “ “ + field[i].getName() + “;“);
        }
         
        System.out.println(“==========实现的接口或者父类的属性==========“);
        // 取得实现的接口或者父类的属性
        Field filed1 = clazz.getFields();
        for (int j = 0; j 《 filed1.length; j++) {
            // 权限修饰符
            int mo = filed1[j].getModifiers();
            String priv = Modifier.toString(mo);
            // 属性类型
            Class《?》 type = filed1[j].getType();
            System.out.println(priv + “ “ + type.getName() + “ “ + filed1[j].getName() + “;“);
        }
    }
}

通过反射机制调用某个类的方法-JAVA

package net.xsoftlab.baike;
import java.lang.reflect.Method;
public class TestReflect {
    public static void main(String args) throws Exception {
        Class《?》 clazz = Class.forName(“net.xsoftlab.baike.TestReflect“);
        // 调用TestReflect类中的reflect1方法
        Method method = clazz.getMethod(“reflect1“);
        method.invoke(clazz.newInstance());
        // Java 反射机制 - 调用某个类的方法1.
        // 调用TestReflect的reflect2方法
        method = clazz.getMethod(“reflect2“, int.class, String.class);
        method.invoke(clazz.newInstance(), 20, “张三“);
        // Java 反射机制 - 调用某个类的方法2.
        // age -》 20. name -》 张三
    }
    public void reflect1() {
        System.out.println(“Java 反射机制 - 调用某个类的方法1.“);
    }
    public void reflect2(int age, String name) {
        System.out.println(“Java 反射机制 - 调用某个类的方法2.“);
        System.out.println(“age -》 “ + age + “. name -》 “ + name);
    }
}

通过反射机制操作某个类的属性-java

package net.xsoftlab.baike;
import java.lang.reflect.Field;
public class TestReflect {
    private String proprety = null;
    public static void main(String args) throws Exception {
        Class《?》 clazz = Class.forName(“net.xsoftlab.baike.TestReflect“);
        Object obj = clazz.newInstance();
        // 可以直接对 private 的属性赋值
        Field field = clazz.getDeclaredField(“proprety“);
        field.setAccessible(true);
        field.set(obj, “Java反射机制“);
        System.out.println(field.get(obj));
    }
}

4. 反射机制的应用实例-JAVA

在泛型为Integer的ArrayList中存放一个String类型的对象。

package net.xsoftlab.baike;
import java.lang.reflect.Method;
import java.util.ArrayList;
public class TestReflect {
    public static void main(String args) throws Exception {
        ArrayList《Integer》 list = new ArrayList《Integer》();
        Method method = list.getClass().getMethod(“add“, Object.class);
        method.invoke(list, “Java反射机制实例。“);
        System.out.println(list.get(0));
    }
}

通过反射取得并修改数组的信息-java

package net.xsoftlab.baike;
import java.lang.reflect.Array;
public class TestReflect {
    public static void main(String args) throws Exception {
        int temp = { 1, 2, 3, 4, 5 };
        Class《?》 demo = temp.getClass().getComponentType();
        System.out.println(“数组类型: “ + demo.getName());
        System.out.println(“数组长度  “ + Array.getLength(temp));
        System.out.println(“数组的第一个元素: “ + Array.get(temp, 0));
        Array.set(temp, 0, 100);
        System.out.println(“修改之后数组第一个元素为: “ + Array.get(temp, 0));
    }
}

将反射机制应用于工厂模式-JAVA

package net.xsoftlab.baike;
interface fruit {
    public abstract void eat();
}
class Apple implements fruit {
    public void eat() {
        System.out.println(“Apple“);
    }
}
class Orange implements fruit {
    public void eat() {
        System.out.println(“Orange“);
    }
}
class Factory {
    public static fruit getInstance(String ClassName) {
        fruit f = null;
        try {
            f = (fruit) Class.forName(ClassName).newInstance();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return f;
    }
}
/**
 * 对于普通的工厂模式当我们在添加一个子类的时候,就需要对应的修改工厂类。 当我们添加很多的子类的时候,会很麻烦。
 * Java 工厂模式可以参考
 * 
-java