Day 241 注解与反射(4)

2023-11-23 22:18
文章标签 注解 反射 day 241

本文主要是介绍Day 241 注解与反射(4),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

注解与反射(4)

反射

什么时候会发生类初始化

类的主动引用(一定会发生类的初始化)

  • 当虚拟机启动,先初始化main方法所在的类
  • new一个类的对象
  • 调用类的静态成员(除了final常量)和静态方法
  • 使用java.lang.reflect包的方法对类进行反射调用
  • 当初始化一个类,如果其父类没有被初始化,则先会初始化它的父类

类的被动引用(不会发生类的初始化)

  • 当访问一个静态域时,只有真正声明这个域的类才会被初始化。如:当通过子类引用父类的静态变量,不会导致子类初始化
  • 通过数组定义类引用,不会触发此类的初始化
  • 引用常量不会触发此类的初始化(常量在链接阶段就存入调用类的常量池中了)

具体的

package com.yangxu.Annotation.reflection;//什么时候发生类的初始化
public class Load {static {System.out.println("main方法的初始化");}public static void main(String[] args) throws ClassNotFoundException {//主动引用------------------------------------------------//1. new对象一定发生初始化,且如果父类未初始化会先初始化父类//Son son = new Son();//2. 反射也会主动引用初始化//Class.forName("com.yangxu.Annotation.reflection.Son");//被动引用------------------------------------------------//1. 子类引用父类的静态变量//System.out.println(Son.a);//2. 数组时//Son[] array = new Son[5];//3. 常量时,因为常量在连接时就已经完成了赋值,初始化不管它的事!//System.out.println(Son.M);}
}class Father{static int a = 1;static {System.out.println("父类的初始化");}
}class Son extends Father{static final int M = 100;static {System.out.println("子类的初始化");}
}

类加载器的作用

类加载的作用:将class文件字节码内容加载到内存中,并将这些静态数据转换成方法区的运行时数据结构,然后在堆中生成一个代表这个类的java.lang.Class对象,作为方法区中类数据的访问入口。

类缓存∶标准的JavaSE类加载器可以按要求查找类,但一旦某个类被加载到类加载器中,它将维持加载(缓存)一段时间。不过JVM垃圾回收机制可以回收这些Class对象

image-20220317203932825

类加载器作用是用来把类(class)装载进内存的。JVM规范定义了如下类型的类的加载器。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JHgGuFV1-1647524558823)(C:\Users\Lenovo\AppData\Roaming\Typora\typora-user-images\image-20220317204023671.png)]

具体的

package com.yangxu.Annotation.reflection;public class Loader {public static void main(String[] args) throws ClassNotFoundException {ClassLoader loader = ClassLoader.getSystemClassLoader();System.out.println(loader);ClassLoader parent = loader.getParent();System.out.println(parent);ClassLoader parent1 = parent.getParent();System.out.println(parent1);ClassLoader loader1 = Class.forName("com.yangxu.Annotation.reflection.Test01").getClassLoader();System.out.println(loader1);//JDK的包里面的类都是用根加载器ClassLoader loader2 = Class.forName("java.lang.Object").getClassLoader();System.out.println(loader2);//如何获得系统类加载器的加载路径System.out.println(System.getProperty("java.class.path"));/*C:\Program Files\Java\jdk1.8.0_291\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_291\jre\lib\rt.jar;C:\Users\Lenovo\Desktop\课程学习\Java学习\out\production\Java学习;D:\IJ\IntelliJ IDEA 2021.1.3\lib\idea_rt.jar由下往上查找加载器,双亲委派机制:如果有与JDK类重名的自定义类则不执行自定义类,执行JDK的*/}
}

创建运行时类的对象

通过反射获取运行时类的完整结构

Field、Method、Constructor、Superclass、Interface、Annotation

package com.yangxu.Annotation.reflection;import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.Method;public class Test08 {public static void main(String[] args) throws ClassNotFoundException, NoSuchFieldException, NoSuchMethodException {Class c1 = Class.forName("com.yangxu.Annotation.reflection.User");//获得类的名字System.out.println(c1.getName());//获得包名+类名System.out.println(c1.getSimpleName());//获得类名System.out.println("=====================================");//获得类的属性Field[] fields = c1.getFields();for (Field field : fields) {System.out.println("public"+field);}fields = c1.getDeclaredFields();for (Field field : fields) {System.out.println("私有的:"+field);}System.out.println("=====================================");//获得指定属性的值
//        Field name = c1.getField("name");
//        System.out.println(name);Field name = c1.getDeclaredField("name");System.out.println(name);System.out.println("=====================================");//获得类的方法Method[] methods = c1.getMethods();for (Method method : methods) {System.out.println("public:"+method);}methods = c1.getDeclaredMethods();for (Method method : methods) {System.out.println("私有的:"+method);}System.out.println("=====================================");//获得类的指定方法//指定文件类型是因为方法重载Method name1 = c1.getMethod("getName");System.out.println(name1);Method name2 = c1.getDeclaredMethod("setName", String.class);System.out.println(name2);System.out.println("=====================================");//获得类的构造器Constructor[] constructors = c1.getConstructors();for (Constructor constructor : constructors) {System.out.println("public:"+constructor);}constructors = c1.getDeclaredConstructors();for (Constructor constructor : constructors) {System.out.println("私有的:"+constructor);}System.out.println("=====================================");//获得指定的构造器Constructor constructor = c1.getConstructor(String.class, int.class, int.class);System.out.println(constructor);Constructor declaredConstructor = c1.getDeclaredConstructor(String.class, int.class, int.class);System.out.println(declaredConstructor);}
}

这篇关于Day 241 注解与反射(4)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/420768

相关文章

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri

Idea实现接口的方法上无法添加@Override注解的解决方案

《Idea实现接口的方法上无法添加@Override注解的解决方案》文章介绍了在IDEA中实现接口方法时无法添加@Override注解的问题及其解决方法,主要步骤包括更改项目结构中的Languagel... 目录Idea实现接China编程口的方法上无法添加@javascriptOverride注解错误原因解决方

Java通过反射获取方法参数名的方式小结

《Java通过反射获取方法参数名的方式小结》这篇文章主要为大家详细介绍了Java如何通过反射获取方法参数名的方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、解决方式方式2.1: 添加编译参数配置 -parameters方式2.2: 使用Spring的内部工具类 -

Java中基于注解的代码生成工具MapStruct映射使用详解

《Java中基于注解的代码生成工具MapStruct映射使用详解》MapStruct作为一个基于注解的代码生成工具,为我们提供了一种更加优雅、高效的解决方案,本文主要为大家介绍了它的具体使用,感兴趣... 目录介绍优缺点优点缺点核心注解及详细使用语法说明@Mapper@Mapping@Mappings@Co

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

Java如何通过反射机制获取数据类对象的属性及方法

《Java如何通过反射机制获取数据类对象的属性及方法》文章介绍了如何使用Java反射机制获取类对象的所有属性及其对应的get、set方法,以及如何通过反射机制实现类对象的实例化,感兴趣的朋友跟随小编一... 目录一、通过反射机制获取类对象的所有属性以及相应的get、set方法1.遍历类对象的所有属性2.获取

SpringBoot使用注解集成Redis缓存的示例代码

《SpringBoot使用注解集成Redis缓存的示例代码》:本文主要介绍在SpringBoot中使用注解集成Redis缓存的步骤,包括添加依赖、创建相关配置类、需要缓存数据的类(Tes... 目录一、创建 Caching 配置类二、创建需要缓存数据的类三、测试方法Spring Boot 熟悉后,集成一个外

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

使用@Slf4j注解,log.info()无法使用问题

《使用@Slf4j注解,log.info()无法使用问题》在使用Lombok的@Slf4j注解打印日志时遇到问题,通过降低Lombok版本(从1.18.x降至1.16.10)解决了问题... 目录@Slf4androidj注解,log.info()无法使用问题最后解决总结@Slf4j注解,log.info(