import java.util.*;
import java.text.*;
import java.lang.reflect.*;
public class Test {
String name;
public Test()
{
System.out.println("In Construtor");
}
public Test(String name)
{
this.name=name;
System.out.println("In Construtor paramitarized-----"+name);
}
public int q() {
System.out.println("working");
return 1;
}
public static void main(String args[] ) throws Exception {
Class c=Class.forName("Test");
Test t=(Test)c.newInstance();
t.q();
Constructor cons[]=c.getConstructors();
for(Constructor ci:cons)
ci.newInstance();
Constructor<?> pcon=c.getConstructor(String.class);
pcon.newInstance();
System.out.println(Test.class.getName());
}
}
Run Code Online (Sandbox Code Playgroud)
我只是尝试掌握Class和ClassLoader类的概念.现在为这一行Constructor<?> pcon=c.getConstructor(String.class);显示IllegalArgumentException:为什么?
谢谢你Jon Skeet :)我改变了我的代码和它的工作
Class c=Class.forName("Test");
Test t=(Test)c.newInstance();
t.q();
Constructor<?> pcon=c.getConstructor(String.class);
pcon.newInstance("arijit");
System.out.println(Test.class.getName());
Run Code Online (Sandbox Code Playgroud)
但是当我使用-Xlint编译时,它给出了下面提到的警告:取消选中调用getConstructor(java.lang.Class ....)作为原始类型java.lang.Class的成员
这是什么意思?
你误诊了它.这不是抛出异常的声明 - 这是:
ci.newInstance();
Run Code Online (Sandbox Code Playgroud)
你试图为两个构造函数调用它(由于for循环) - 所以当它调用无参数构造函数时它会没问题,但是当它调用带参数的构造函数时它就没有了String.您必须更改该调用以传递正确数量的参数,具体取决于当时哪个构造函数ci引用.
您以后遇到同样的问题:
pcon.newInstance();
Run Code Online (Sandbox Code Playgroud)
这次你知道有一个String参数(你刚刚要求一个带有字符串参数的构造函数)所以你绝对知道你应该提供一个String参数,例如
pcon.newInstance("foo");
Run Code Online (Sandbox Code Playgroud)
此外,您应该尝试弄清楚为什么您认为getConstructor()这是失败的呼叫.例外应该给你一个堆栈跟踪,其上有正确的行...重要的是能够准确地诊断问题,所以值得看看这次出了什么问题.