search
HomeJavajavaTutorialDetailed introduction to Java reflection to obtain class and object information

Reflection can solve the problem that it is impossible to predict at compile time which objectand class it belongs to, and the information of the object and class can only be known based on the information when the program is running.

When two people collaborate on development, you only need to know the other party's class name to carry out preliminary development.

Get the class object

  • Class.forName(String clazzName) static method

  • Call the class attribute of the class, Person. class returns the Person class object (recommended)

  • Call the getClass() method of an object

Specific use You still have to choose based on actual conditions. The first method is relatively free. You only need to know a class name. It will not verify whether the class exists. The second and third methods will verify whether the class exists.

Get class information

Get class constructor

  • ##Connstructor getConstructor(Class>.. .parameterTypes): Returns the public constructor with specified formal parameters of the corresponding class of this Class object

  • Constructor>[] getConstructors() :Return all public constructors of the class corresponding to this Class object

  • ##Constructor[] getDeclaredConstructor(Class>...parameterTypes)

    :Return This class object corresponds to the constructor of the class with specified parameters, regardless of the access permission of the constructor

  • ##Constructor>[] getDeclaredConstructors()
  • : Return This class object corresponds to all constructors of the class, regardless of the access rights of the constructor

    Get the class member method

    Method getMethod (String name,Class>...parameterTypes)
  • : Returns the public method with specified formal parameters of the corresponding class of this class object

  • Method[] getMethods()
  • : Returns all public methods of the class represented by this class object

    ##Method getDeclaredMethod(string name,Class>...parameterTypes)
  • : Returns the method with specified formal parameters of the corresponding class of this class object, regardless of method access permissions
  • Method[] getDeclaredMethods()
  • : Returns this The class object corresponds to all methods of the class, regardless of the access rights of the method
  • Get the class member variables

Field getField(String name )
    : Returns the public member variable of the specified name corresponding to this class object
  • Field[] getFields()
  • : Returns the public member variable of the specified class corresponding to this class object All public member variables
  • Field getDeclaredField(String name)
  • : Returns the member variable with the specified name corresponding to this class object, regardless of member variable access permissions
  • Field[] getDeclaredFields()
  • : Returns all member variables of the class corresponding to this class object, regardless of the access rights of the member variables
  • Get class annotation

##A getAnnotation(ClassannotationClass)

: Try to get the corresponding class of the class object Annotation of the specified type. If the type annotation does not exist, null is returned

Get the external class where the object of this class is located

  • Class> getDeclaringClass(): Returns the external class where the corresponding class of the Class object is located

Gets the interface implemented by the corresponding class of the class object

  • Class>[] getInterfaces(): Returns all interfaces implemented by the corresponding class of the Class object

Get the parent class inherited by the corresponding class of this class object

  • ##Class super T> getSuperclass(): Return the The Class object of the super class corresponding to the Class object

Get the basic information such as the modifier, package, class name, etc. of the class object corresponding to the class

  • int getModifiers(): Returns all modifiers of this class or interface. The modifiers are composed of public, protected, private, final, static, abstract and other corresponding constants. The returned integerYou should use the method of the Modifier tool class to decode to get the real modifier

  • Package getPackage(): Get the package of this class

  • String getName(): Returns the short name of the class represented by this CLass object in the form of string

Determine whether the class is an interface, enumeration, or annotation type

  • boolean isAnnotation(): Returns whether this class object represents an annotation type

  • boolean isAnnotationPresent(Class extends Annotation>annotationClass): Determine whether this Class object is decorated with class Annotation

  • boolean isAnonymousClass(): Returns whether this class object is an anonymous class

  • ##boolean isArray()

    : Returns this class object Whether it represents an arrayclass

  • boolean isEnum()

    : Returns whether this class object represents an enumeration

  • boolean isInterface()

    : Returns whether this class object represents an interface

  • ##boolean isInstance(
  • Object

    obj ): Determine whether obj is an instance of this class object. This method can completely replace the instanceof<a href="http://www.php.cn/wiki/60.html" target="_blank"> operator</a>

    public interface Colorable {
         public void value();
    }
    public class ClassInfo {
    
        public static void main(String[] args) throws NoSuchMethodException, SecurityException {
            Class<Colorable> cls=Colorable.class;
            System.out.println(cls.getMethod("value"));
            System.out.println(cls.isAnnotation());
            System.out.println(cls.isInterface());
        }
    
    }

  • result

public abstract void com.em.Colorable.value()
false
true
New method parameter reflection in Java8

    int getParameterCount()
  • : Get the number of formal parameters of the constructor or method

  • Parameter[] getParameters()
  • : Get all formal parameters of the constructor or method

  • getModifiers( )
  • : Get the modifier that modifies the formal parameter

  • String getName()
  • : Get the formal parameter name

  • Type getParameterizedType()
  • : Get the formal parameter type with generics

  • Class>getType()
  • : Get the formal parameter type Parameter type

  • boolean isNamePresent()
  • : This method returns whether the class file of the class contains the formal parameter name information of the method

  • boolean isVarArgs()
  • : This method is used to determine whether the parameter is a variable number of formal parameters

    public class Test {
        public void getInfo(String str,List<String>list){
            System.out.println("成功");
        }
    }
    public class ClassInfo {
    
        public static void main(String[] args) throws NoSuchMethodException, SecurityException {
            Class<Test> cls=Test.class;
            Method med=cls.getMethod("getInfo", String.class,List.class);
            System.out.println(med.getParameterCount());
            Parameter[] params=med.getParameters();
            System.out.println(params.length);
            for(Parameter par:params){
                System.out.println(par.getName());
                System.out.println(par.getType());
                System.out.println(par.getParameterizedType());
            }
        }
    
    }

  • Result

2
2
arg0
class java.lang.String
class java.lang.String
arg1
interface java.util.List
java.util.List<java.lang.String>
Reflection generated object

Use the newInstance() method of the Class object to create an instance of the Class object. This method requires a default constructor (more commonly used)
  • First use the Class object to obtain the specified Constructor object, and then call the newInstance() method of the Constructor object to create an instance of the corresponding class of the Class object
  • Reflection calling method

    Object invoke(Object obj,Object...args)
  • : obj in this method is the main call to execute the method, followed by The args are the actual parameters passed into the method when executing the method

    public class Test {
    
        public Test(String str) {
            System.out.println(str);
        }
        public void getInfo(String str){
            System.out.println(str);
        }
    }
    public class ClassInfo {
    
        public static void main(String[] args) throws Exception {
            Class<Test> cls=Test.class;
            Constructor<Test>construct=cls.getConstructor(String.class);
            Test test=construct.newInstance("初始化");
            Method med=cls.getMethod("getInfo", String.class);
            med.invoke(test, "调用方法成功");
        }
    
    }

  • Result

初始化
调用方法成功
Next, the official will take a closer look at the chestnut below
public class Test {

    public Test(String str) {
        System.out.println(str);
    }
    //私有方法
    private void getInfo(String str){
        System.out.println(str);
    }
}
public class ClassInfo {

    public static void main(String[] args) throws Exception {
        Class<Test> cls=Test.class;
        Constructor<Test>construct=cls.getConstructor(String.class);
        Test test=construct.newInstance("初始化");
      //为啥使用这个方法呢?
        Method med=cls.getDeclaredMethod("getInfo", String.class);
      //为啥使用这个方法呢?
        med.setAccessible(true);
        med.invoke(test, "调用方法成功");
    }

}

Result

初始化
调用方法成功
setAccessible(boolean flag): Set the value to true, indicating that the Java language access permission check should be canceled when using this Method

Accessing member variable values

    getXxx(Object obj)
  • : Get the value of the member variable of the obj object. Xxx here corresponds to 8 basic types. If the type of the member variable is

    reference type, remove the Xxx part

  • setXxx(Object obj ,Xxx val)
  • : Set the member variable of the obj object to the val value. The Xxx here corresponds to the 8 basic types. If the type of the member variable is a reference type, cancel the Xxx after set

  • The above two methods can access all members Variables, including private private member variables
public class Test {
    private int num;

    public Test(String str) {
        System.out.println(str);
    }
    private void getInfo(String str){
        System.out.println(str);
    }
    public int getNum() {
        return num;
    }
    public void setNum(int num) {
        this.num = num;
    }

}
public class ClassInfo {

    public static void main(String[] args) throws Exception {
        Class<Test> cls=Test.class;
        Constructor<Test>construct=cls.getConstructor(String.class);
        Test test=construct.newInstance("初始化");
        Method med=cls.getDeclaredMethod("getInfo", String.class);
        med.setAccessible(true);
        med.invoke(test, "调用方法成功");
        Field fld=cls.getDeclaredField("num");
        fld.setAccessible(true);
        fld.setInt(test, 12);
        System.out.println(fld.getInt(test));
    }

}

Result

初始化
调用方法成功
12
Operation array

There is an Array under the java.lang.reflect package Class, which can dynamically create arrays

static Object newInstance(Class>componentType,int...length)

: Create a new array with the specified element type and specified dimensions

static xxx getXxx(Object array,int index):返回array数组中第index个元素。其中xxx是各种基本数据类型,如果数组元素是引用类型,则该方法变为get()

static void setXxx(Object array,int index,xxx val):将array数组中低index 个元素的值设为val,其中xxx是各种基本数据类型,如果数组元素是引用类型,则该方法变为set()

public class ArrayInfo {

    public static void main(String[] args) {
        Object arrays=Array.newInstance(String.class, 3);
        Array.set(arrays, 0, "第一个");
        Array.set(arrays, 1, "第二个");
        Array.set(arrays, 2, "第三个");
        System.out.println(Array.get(arrays, 2));
    }
}

The above is the detailed content of Detailed introduction to Java reflection to obtain class and object information. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
How does platform independence benefit enterprise-level Java applications?How does platform independence benefit enterprise-level Java applications?May 03, 2025 am 12:23 AM

Java is widely used in enterprise-level applications because of its platform independence. 1) Platform independence is implemented through Java virtual machine (JVM), so that the code can run on any platform that supports Java. 2) It simplifies cross-platform deployment and development processes, providing greater flexibility and scalability. 3) However, it is necessary to pay attention to performance differences and third-party library compatibility and adopt best practices such as using pure Java code and cross-platform testing.

What role does Java play in the development of IoT (Internet of Things) devices, considering platform independence?What role does Java play in the development of IoT (Internet of Things) devices, considering platform independence?May 03, 2025 am 12:22 AM

JavaplaysasignificantroleinIoTduetoitsplatformindependence.1)Itallowscodetobewrittenonceandrunonvariousdevices.2)Java'secosystemprovidesusefullibrariesforIoT.3)ItssecurityfeaturesenhanceIoTsystemsafety.However,developersmustaddressmemoryandstartuptim

Describe a scenario where you encountered a platform-specific issue in Java and how you resolved it.Describe a scenario where you encountered a platform-specific issue in Java and how you resolved it.May 03, 2025 am 12:21 AM

ThesolutiontohandlefilepathsacrossWindowsandLinuxinJavaistousePaths.get()fromthejava.nio.filepackage.1)UsePaths.get()withSystem.getProperty("user.dir")andtherelativepathtoconstructthefilepath.2)ConverttheresultingPathobjecttoaFileobjectifne

What are the benefits of Java's platform independence for developers?What are the benefits of Java's platform independence for developers?May 03, 2025 am 12:15 AM

Java'splatformindependenceissignificantbecauseitallowsdeveloperstowritecodeonceandrunitonanyplatformwithaJVM.This"writeonce,runanywhere"(WORA)approachoffers:1)Cross-platformcompatibility,enablingdeploymentacrossdifferentOSwithoutissues;2)Re

What are the advantages of using Java for web applications that need to run on different servers?What are the advantages of using Java for web applications that need to run on different servers?May 03, 2025 am 12:13 AM

Java is suitable for developing cross-server web applications. 1) Java's "write once, run everywhere" philosophy makes its code run on any platform that supports JVM. 2) Java has a rich ecosystem, including tools such as Spring and Hibernate, to simplify the development process. 3) Java performs excellently in performance and security, providing efficient memory management and strong security guarantees.

How does the JVM contribute to Java's 'write once, run anywhere' (WORA) capability?How does the JVM contribute to Java's 'write once, run anywhere' (WORA) capability?May 02, 2025 am 12:25 AM

JVM implements the WORA features of Java through bytecode interpretation, platform-independent APIs and dynamic class loading: 1. Bytecode is interpreted as machine code to ensure cross-platform operation; 2. Standard API abstract operating system differences; 3. Classes are loaded dynamically at runtime to ensure consistency.

How do newer versions of Java address platform-specific issues?How do newer versions of Java address platform-specific issues?May 02, 2025 am 12:18 AM

The latest version of Java effectively solves platform-specific problems through JVM optimization, standard library improvements and third-party library support. 1) JVM optimization, such as Java11's ZGC improves garbage collection performance. 2) Standard library improvements, such as Java9's module system reducing platform-related problems. 3) Third-party libraries provide platform-optimized versions, such as OpenCV.

Explain the process of bytecode verification performed by the JVM.Explain the process of bytecode verification performed by the JVM.May 02, 2025 am 12:18 AM

The JVM's bytecode verification process includes four key steps: 1) Check whether the class file format complies with the specifications, 2) Verify the validity and correctness of the bytecode instructions, 3) Perform data flow analysis to ensure type safety, and 4) Balancing the thoroughness and performance of verification. Through these steps, the JVM ensures that only secure, correct bytecode is executed, thereby protecting the integrity and security of the program.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft