com.fr.invoke

类 Reflect

    • 方法概要

      方法 
      限定符和类型 方法和说明
      static <T extends java.lang.reflect.AccessibleObject> 
      T
      accessible(T accessible)
      Conveniently render an AccessibleObject accessible.
      <P> P as(java.lang.Class<P> proxyType)
      Create a proxy for the wrapped object allowing to typesafely invoke methods on it using a custom interface
      Reflect call(java.lang.String name)
      Call a method by its name.
      Reflect call(java.lang.String name, java.lang.Object... args)
      Call a method by its name.
      Reflect create()
      Call a constructor.
      Reflect create(java.lang.Object... args)
      Call a constructor.
      boolean equals(java.lang.Object obj)
      Reflect field(java.lang.String name)
      Get a wrapped field.
      java.util.Map<java.lang.String,Reflect> fields()
      Get a Map containing field names and wrapped values for the fields' values.
      <T> T get()
      Get the wrapped object
      <T> T get(java.lang.String name)
      Get a field value.
      int hashCode()
      boolean matchConstructor(java.lang.Object... args)
      判断类是否有匹配传入参数的构造函数.
      static Reflect on(java.lang.Class<?> clazz)
      Wrap a class.
      static Reflect on(java.lang.Object object)
      Wrap an object.
      static Reflect on(java.lang.String name)
      Wrap a class name.
      static Reflect on(java.lang.String name, java.lang.ClassLoader classLoader)
      Wrap a class name, loading it via a given class loader.
      Reflect set(java.lang.String name, java.lang.Object value)
      Set a field value.
      java.lang.String toString()
      java.lang.Class<?> type()
      Get the type of the wrapped object.
      static java.lang.Class<?> wrapper(java.lang.Class<?> type)
      Get a wrapper type for a primitive type, or the argument type itself, if it is not a primitive type.
      • 从类继承的方法 java.lang.Object

        clone, finalize, getClass, notify, notifyAll, wait, wait, wait
    • 方法详细资料

      • on

        public static Reflect on(java.lang.String name)
                          throws ReflectException
        Wrap a class name.

        This is the same as calling on(Class.forName(name))

        参数:
        name - A fully qualified class name
        返回:
        A wrapped class object, to be used for further reflection.
        抛出:
        ReflectException - If any reflection exception occurred.
        另请参阅:
        on(Class)
      • on

        public static Reflect on(java.lang.String name,
                 java.lang.ClassLoader classLoader)
                          throws ReflectException
        Wrap a class name, loading it via a given class loader.

        This is the same as calling on(Class.forName(name, classLoader))

        参数:
        name - A fully qualified class name.
        classLoader - The class loader in whose context the class should be loaded.
        返回:
        A wrapped class object, to be used for further reflection.
        抛出:
        ReflectException - If any reflection exception occurred.
        另请参阅:
        on(Class)
      • on

        public static Reflect on(java.lang.Class<?> clazz)
        Wrap a class.

        Use this when you want to access static fields and methods on a Class object, or as a basis for constructing objects of that class using create(Object...)

        参数:
        clazz - The class to be wrapped
        返回:
        A wrapped class object, to be used for further reflection.
      • on

        public static Reflect on(java.lang.Object object)
        Wrap an object.

        Use this when you want to access instance fields and methods on any Object

        参数:
        object - The object to be wrapped
        返回:
        A wrapped object, to be used for further reflection.
      • accessible

        public static <T extends java.lang.reflect.AccessibleObject> T accessible(T accessible)
        Conveniently render an AccessibleObject accessible.

        To prevent SecurityException, this is only done if the argument object and its declaring class are non-public.

        参数:
        accessible - The object to render accessible
        返回:
        The argument object rendered accessible
      • get

        public <T> T get()
        Get the wrapped object
        类型参数:
        T - A convenience generic parameter for automatic unsafe casting
      • set

        public Reflect set(java.lang.String name,
                  java.lang.Object value)
                    throws ReflectException
        Set a field value.

        This is roughly equivalent to Field.set(Object, Object). If the wrapped object is a Class, then this will set a value to a static member field. If the wrapped object is any other Object, then this will set a value to an instance member field.

        This method is also capable of setting the value of (static) final fields. This may be convenient in situations where no SecurityManager is expected to prevent this, but do note that (especially static) final fields may already have been inlined by the javac and/or JIT and relevant code deleted from the runtime verison of your program, so setting these fields might not have any effect on your execution.

        For restrictions of usage regarding setting values on final fields check: http://stackoverflow.com/questions/3301635/change-private-static-final-field-using-java-reflection ... and http://pveentjer.blogspot.co.at/2017/01/final-static-boolean-jit.html

        参数:
        name - The field name
        value - The new field value
        返回:
        The same wrapped object, to be used for further reflection.
        抛出:
        ReflectException - If any reflection exception occurred.
      • get

        public <T> T get(java.lang.String name)
              throws ReflectException
        Get a field value.

        This is roughly equivalent to Field.get(Object). If the wrapped object is a Class, then this will get a value from a static member field. If the wrapped object is any other Object, then this will get a value from an instance member field.

        If you want to "navigate" to a wrapped version of the field, use field(String) instead.

        参数:
        name - The field name
        返回:
        The field value
        抛出:
        ReflectException - If any reflection exception occurred.
        另请参阅:
        field(String)
      • field

        public Reflect field(java.lang.String name)
                      throws ReflectException
        Get a wrapped field.

        This is roughly equivalent to Field.get(Object). If the wrapped object is a Class, then this will wrap a static member field. If the wrapped object is any other Object, then this wrap an instance member field.

        参数:
        name - The field name
        返回:
        The wrapped field
        抛出:
        ReflectException - If any reflection exception occurred.
      • fields

        public java.util.Map<java.lang.String,Reflect> fields()
        Get a Map containing field names and wrapped values for the fields' values.

        If the wrapped object is a Class, then this will return static fields. If the wrapped object is any other Object, then this will return instance fields.

        These two calls are equivalent

         on(object).field("myField");
         on(object).fields().get("myField");
         
        返回:
        A map containing field names and wrapped values.
      • call

        public Reflect call(java.lang.String name)
                     throws ReflectException
        Call a method by its name.

        This is a convenience method for calling call(name, new Object[0])

        参数:
        name - The method name
        返回:
        The wrapped method result or the same wrapped object if the method returns void, to be used for further reflection.
        抛出:
        ReflectException - If any reflection exception occurred.
        另请参阅:
        call(String, Object...)
      • call

        public Reflect call(java.lang.String name,
                   java.lang.Object... args)
                     throws ReflectException
        Call a method by its name.

        This is roughly equivalent to Method.invoke(Object, Object...). If the wrapped object is a Class, then this will invoke a static method. If the wrapped object is any other Object, then this will invoke an instance method.

        Just like Method.invoke(Object, Object...), this will try to wrap primitive types or unwrap primitive type wrappers if applicable. If several methods are applicable, by that rule, the first one encountered is called. i.e. when calling

         on(...).call("method", 1, 1);
         
        The first of the following methods will be called:
         public void method(int param1, Integer param2);
         public void method(Integer param1, int param2);
         public void method(Number param1, Number param2);
         public void method(Number param1, Object param2);
         public void method(int param1, Object param2);
         

        The best matching method is searched for with the following strategy:

        1. public method with exact signature match in class hierarchy
        2. non-public method with exact signature match on declaring class
        3. public method with similar signature in class hierarchy
        4. non-public method with similar signature on declaring class
        参数:
        name - The method name
        args - The method arguments
        返回:
        The wrapped method result or the same wrapped object if the method returns void, to be used for further reflection.
        抛出:
        ReflectException - If any reflection exception occurred.
      • create

        public Reflect create()
                       throws ReflectException
        Call a constructor.

        This is a convenience method for calling create(new Object[0])

        返回:
        The wrapped new object, to be used for further reflection.
        抛出:
        ReflectException - If any reflection exception occurred.
        另请参阅:
        create(Object...)
      • create

        public Reflect create(java.lang.Object... args)
                       throws ReflectException
        Call a constructor.

        This is roughly equivalent to Constructor.newInstance(Object...). If the wrapped object is a Class, then this will create a new object of that class. If the wrapped object is any other Object, then this will create a new object of the same type.

        Just like Constructor.newInstance(Object...), this will try to wrap primitive types or unwrap primitive type wrappers if applicable. If several constructors are applicable, by that rule, the first one encountered is called. i.e. when calling

         on(C.class).create(1, 1);
         
        The first of the following constructors will be applied:
         public C(int param1, Integer param2);
         public C(Integer param1, int param2);
         public C(Number param1, Number param2);
         public C(Number param1, Object param2);
         public C(int param1, Object param2);
         
        参数:
        args - The constructor arguments
        返回:
        The wrapped new object, to be used for further reflection.
        抛出:
        ReflectException - If any reflection exception occurred.
      • matchConstructor

        public boolean matchConstructor(java.lang.Object... args)
        判断类是否有匹配传入参数的构造函数.
        参数:
        args - 参数
        返回:
        是否匹配构造函数
      • as

        public <P> P as(java.lang.Class<P> proxyType)
        Create a proxy for the wrapped object allowing to typesafely invoke methods on it using a custom interface
        参数:
        proxyType - The interface type that is implemented by the proxy
        返回:
        A proxy for the wrapped object
      • hashCode

        public int hashCode()
        覆盖:
        hashCode 在类中 java.lang.Object
      • equals

        public boolean equals(java.lang.Object obj)
        覆盖:
        equals 在类中 java.lang.Object
      • toString

        public java.lang.String toString()
        覆盖:
        toString 在类中 java.lang.Object
      • type

        public java.lang.Class<?> type()
        Get the type of the wrapped object.
        另请参阅:
        Object.getClass()
      • wrapper

        public static java.lang.Class<?> wrapper(java.lang.Class<?> type)
        Get a wrapper type for a primitive type, or the argument type itself, if it is not a primitive type.