java access通过反射访问整数构造函数

yon*_*tix 8 java

我有这个代码.为什么它不起作用?(工作意味着它显示3)我该如何解决?

public class Main {
    public static<V> V copy(V var){
        try{ 
            return (V) var.getClass().getConstructor(var.getClass()).newInstance(var);
        }
        catch(Exception e){
            System.out.println("Copy faield " + e.getMessage() + " ");
            e.printStackTrace();
        }
        return null;
    }

    public static void main(String[] args) {
        Integer a = new Integer(3);
        Integer b = copy(a);

        System.out.println(a);
        System.out.println(b);


    }
}
Run Code Online (Sandbox Code Playgroud)

这是输出:

 Copy faield java.lang.Integer.<init>(java.lang.Integer) 
    java.lang.NoSuchMethodException: java.lang.Integer.<init>(java.lang.Integer)
        at java.lang.Class.getConstructor0(Class.java:2818)
        at java.lang.Class.getConstructor(Class.java:1723)
        at Main.copy(Main.java:7)
        at Main.main(Main.java:19)
    3
    null
Run Code Online (Sandbox Code Playgroud)

谢谢!

Boh*_*ian 5

这里的问题是区别:

Integer.class
int.class
Run Code Online (Sandbox Code Playgroud)

Integer的构造函数接受一个int参数,而不是一个参数Integer.

为了让你的魔法方法起作用,你需要对类型进行特殊检查,如果它是一个包装类,实际上要查找一个构造函数,其参数是相应的主要类型.

AFAIK没有内置的方法来从包装类中获取primatove类 - 您可以使用映射并使用映射填充它:

private static final Map<Class<?>, Class<?>> MAP = new HashMap<>() {{
    put(Integer.class, int.class);
    put(Long.class, long.class);
    // etc
}};
Run Code Online (Sandbox Code Playgroud)

然后在你的方法中:

Class<?> type = MAP.containsKey(var.getClass()) ? MAP.get(var.getClass()) : var.getClass();
return (V) var.getClass().getConstructor(type).newInstance(var);
Run Code Online (Sandbox Code Playgroud)

可以在参数值中传递intas Integer- 至少可以自动取消装箱.