Можно ли использовать Class.newInstance() с аргументами конструктора?

Я хотел бы использовать Class.newInstance(), но экземпляр класса я не имеет конструктора с нулевым значением. Поэтому мне нужно иметь возможность передавать аргументы конструктора. Есть ли способ сделать это?

Ответ 1

MyClass.class.getDeclaredConstructor(String.class).newInstance("HERESMYARG");

или же

obj.getClass().getDeclaredConstructor(String.class).newInstance("HERESMYARG");

Ответ 2

myObject.getClass().getDeclaredConstructors(types list).newInstance(args list);

Изменить: согласно комментариям кажется, что указывать класс и имена методов недостаточно для некоторых пользователей. Для получения дополнительной информации см. Документацию для получение constuctor и вызов.

Ответ 3

Предполагая, что у вас есть следующий конструктор

class MyClass {
    public MyClass(Long l, String s, int i) {

    }
}

Вам нужно будет показать, что вы собираетесь использовать этот конструктор следующим образом:

Class classToLoad = MyClass.class;

Class[] cArg = new Class[3]; //Our constructor has 3 arguments
cArg[0] = Long.class; //First argument is of *object* type Long
cArg[1] = String.class; //Second argument is of *object* type String
cArg[2] = int.class; //Third argument is of *primitive* type int

Long l = new Long(88);
String s = "text";
int i = 5;

classToLoad.getDeclaredConstructor(cArg).newInstance(l, s, i);

Ответ 4

Не используйте Class.newInstance(); посмотрите эту тему: Почему Class.newInstance() зло?

Как и другие ответы, используйте Constructor.newInstance() вместо этого.

Ответ 5

Вы можете получить другие конструкторы с getConstructor (...).

Ответ 6

Следуйте инструкциям ниже, чтобы вызвать параметризованный consturctor.

  • Получите Constructor с параметрами, передав типы в Class[] для метода getDeclaredConstructor Class
  • Создайте экземпляр конструктора, передав значения в Object[] для
    newInstance метод Constructor

Пример кода:

import java.lang.reflect.*;

class NewInstanceWithReflection{
    public NewInstanceWithReflection(){
        System.out.println("Default constructor");
    }
    public NewInstanceWithReflection( String a){
        System.out.println("Constructor :String => "+a);
    }
    public static void main(String args[]) throws Exception {

        NewInstanceWithReflection object = (NewInstanceWithReflection)Class.forName("NewInstanceWithReflection").newInstance();
        Constructor constructor = NewInstanceWithReflection.class.getDeclaredConstructor( new Class[] {String.class});
        NewInstanceWithReflection object1 = (NewInstanceWithReflection)constructor.newInstance(new Object[]{"StackOverFlow"});

    }
}

выход:

java NewInstanceWithReflection
Default constructor
Constructor :String => StackOverFlow

Ответ 7

Вы можете использовать метод getDeclaredConstructor класса. Он ожидает массив классов. Вот пример:

public static JFrame createJFrame(Class c, String name, Component parentComponent)
{
    try
    {
        JFrame frame = (JFrame)c.getDeclaredConstructor(new Class[] {String.class}).newInstance("name");
        if (parentComponent != null)
        {
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        }
        else
        {
            frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
        }
        frame.setLocationRelativeTo(parentComponent);
        frame.pack();
        frame.setVisible(true);
    }
    catch (InstantiationException instantiationException)
    {
        ExceptionHandler.handleException(instantiationException, parentComponent, Language.messages.get(Language.InstantiationExceptionKey), c.getName());
    }
    catch(NoSuchMethodException noSuchMethodException)
    {
        //ExceptionHandler.handleException(noSuchMethodException, parentComponent, Language.NoSuchMethodExceptionKey, "NamedConstructor");
        ExceptionHandler.handleException(noSuchMethodException, parentComponent, Language.messages.get(Language.NoSuchMethodExceptionKey), "(Constructor or a JFrame method)");
    }
    catch (IllegalAccessException illegalAccessException)
    {
        ExceptionHandler.handleException(illegalAccessException, parentComponent, Language.messages.get(Language.IllegalAccessExceptionKey));
    }
    catch (InvocationTargetException invocationTargetException)
    {
        ExceptionHandler.handleException(invocationTargetException, parentComponent, Language.messages.get(Language.InvocationTargetExceptionKey));
    }
    finally
    {
        return null;
    }
}