假设我有一个函数,它的目的是创建任何指定类的新实例,然后返回它
public static <T> Class<T> forgeClass(Class<T> classReference) {
return new classReference.getClass();
}
用法(与Employee
类一起):
Employee foo = forgeClass(Employee.class); // new Employee instance
我怎样才能做到这一点?
关键是使用Class.newInstance
;
public static <T> T forge(final Class<T> type)
throws InstantiationException, IllegalAccessException {
return type.newInstance();
}
使用如下。。。
final Employee employee = forge(Employee.class);
如果要使用更复杂的初始化例程,例如Employee(String name)
,则应使用Class.getConstructor
,然后使用Constructor.newInstance
。
final Constructor ctor = Employee.class.getConstructor(String.class);
final Employee employee = ctor.newInstance("Steve");
您可以使用Class.newInstance()
方法,并且方法的返回类型应该是T
而不是Class<T>
。
public static <T> T forgeClass(Class<T> classReference) throws InstantiationException, IllegalAccessException {
return classReference.newInstance();
}
只需使用newInstance()
:
Class<?> yourClass;
return yourClass.newInstance();
class.newInstance()正是您所需要的:
public static <T> T forgeClass(Class<T> classReference) throws InstantiationException, IllegalAccessException {
return classReference.newInstance();
}
如果要将参数传递给构造函数,则必须使用java.lang.reflect.Constructor<T>
:
public static <T> T forgeClass(Class<T> classReference, Object... constructorArguments)
throws InstantiationException, IllegalAccessException, SecurityException,
NoSuchMethodException, IllegalArgumentException, InvocationTargetException {
Class<?>[] argumentTypes = new Class<?>[constructorArguments.length];
for (int i = 0; i < constructorArguments.length; i++)
argumentTypes[i] = constructorArguments[i].getClass();
Constructor<T> ctor = classReference.getConstructor(argumentTypes);
return ctor.newInstance(constructorArguments);
}
EDIT:正如注释中所指出的,如果您在参数