Java注解与反射(三)

简介: Java注解与反射(三)

2.2 反射机制


  • Java反射机制提供的功能


  • 在运行时判断任意一个对象所属的类
  • 在运行时构造任意一个类的对象
  • 在运行时判断任意一个类所具有的成员变量和成员方法
  • 在运行时获取泛型信息
  • 在运行时调用任意一个对象的成员变量和成员方法
  • 在运行时处理注解
  • 生成动态代理
  • ......


  • 反射机制的优缺点:


  • 优点:可以实现动态创建对象和编译,体现出相当大的灵活性
  • 缺点:对性能有影响。使用反射基本上是一种解释操作,我们可以告诉JVM,我们希望它做什么并且它能够满足我们的要求。这类操作总是慢于直接执行相同的操作(基于这个原因,在没有什么特殊情况时,不得使用反射)


  • 反射的API:


  • java.lang.Class : 代表一个类
  • java.lang.reflect.Method : 代表类的方法
  • java.lang.reflect Field : 代表类的成员变量
  • java.lang.reflect.Constructure : 代表类的构造器
  • ......
package refection ;
 import java.util.Objects;
 // 反射
 public class Test {
     @SuppressWarnings("all")
     public static void main(String[] args) throws ClassNotFoundException {
         // 创建对象,实际上时需要泛型的,但是没有,用不到,直接去掉。  看着难受就强行镇压黄色的提示
       Class c1 = Class.forName("refection.User");
       // 一个类在内存中只有一个Class对象,可以进行验证
         // 验证的方式:多次获取,看哈希码是否相同
         // 一个类被加载之后,类的整个结构都会被封装在Class对象中
         Class c2 = Class.forName("refection.User");
         Class c3 = Class.forName("refection.User");
         Class c4 = Class.forName("refection.User");
         System.out.println(c2.hashCode());
         System.out.println(c3.hashCode());
         System.out.println(c4.hashCode());
     }
 }
 // 实体类:pojo、entity类
 class User{
     private String name  ;
     private int id ;
     private int age ;
     public User() {
     }
     public User(String name, int id, int age) {
         this.name = name;
         this.id = id;
         this.age = age;
     }
     public String getName() {
         return name;
     }
     public void setName(String name) {
         this.name = name;
     }
     public int getId() {
         return id;
     }
     public void setId(int id) {
         this.id = id;
     }
     public int getAge() {
         return age;
     }
     public void setAge(int age) {
         this.age = age;
     }
     @Override
     public String toString() {
         return "User{" +
                 "name='" + name + ''' +
                 ", id=" + id +
                 ", age=" + age +
                 '}';
     }
     @Override
     public boolean equals(Object o) {
         if (this == o) return true;
         if (o == null || getClass() != o.getClass()) return false;
         User user = (User) o;
         return id == user.id &&
                 age == user.age &&
                 Objects.equals(name, user.name);
     }
     @Override
     public int hashCode() {
         return Objects.hash(name, id, age);
     }
 }


2.3 获得class对象的几种方式


  • 获取class对象的方式一共有三种:


  • 方式一:通过对象获得
  • 方式二:通过反射forName获得
  • 方式三:通过类名.class获得
  • 方式四:通过内置的基本数据类型的包装类
  • 方式五:通过ClassLoader(后面讲解)
package refection ;
 import java.util.Objects;
 public class Test02 {
     @SuppressWarnings("all")
     public static void main(String[] args) throws ClassNotFoundException {
         Person person = new Student();
         System.out.println("这个人是" + person.name);
        //  - 方式一:通过对象获得
         Class c1 = person.getClass();
         System.out.println(c1.hashCode());
        //  - 方式二:通过反射forName获得
         Class c2 = Class.forName("refection.Student");
         System.out.println(c2.hashCode());
        //  - 方式三:通过类名.class获得
        Class c3 = Student.class ;
         System.out.println(c3.hashCode());
         // 方式四:通过内置类型的包装类都有一个Type属性
         Class c4 = Integer.TYPE ;
         System.out.println(c4);
         System.out.println(c4.hashCode());
         // 获取父类型
         Class c5 = c1.getSuperclass();
         System.out.println(c5);
     }
 }
 class Person {
     public String name ;
     public Person (){
     }
     public Person(String name){
         this.name = name ;
     }
     @Override
     public String toString() {
         return "Person{" +
                 "name='" + name + ''' +
                 '}';
     }
     @Override
     public boolean equals(Object o) {
         if (this == o) return true;
         if (o == null || getClass() != o.getClass()) return false;
         Person person = (Person) o;
         return Objects.equals(name, person.name);
     }
     @Override
     public int hashCode() {
         return Objects.hash(name);
     }
 }
 class Student extends Person{
     public Student(){
         this.name = "学生" ;
     }
 }
 class Teacher extends Person{
     public Teacher(){
         this.name = "教师" ;
     }
 }


相关文章
|
XML Java 编译器
Java注解的底层源码剖析与技术认识
Java注解(Annotation)是Java 5引入的一种新特性,它提供了一种在代码中添加元数据(Metadata)的方式。注解本身并不是代码的一部分,它们不会直接影响代码的执行,但可以在编译、类加载和运行时被读取和处理。注解为开发者提供了一种以非侵入性的方式为代码提供额外信息的手段,这些信息可以用于生成文档、编译时检查、运行时处理等。
265 7
|
Java 编译器 开发者
注解的艺术:Java编程的高级定制
注解是Java编程中的高级特性,通过内置注解、自定义注解及注解处理器,可以实现代码的高度定制和扩展。通过理解和掌握注解的使用方法,开发者可以提高代码的可读性、可维护性和开发效率。在实际应用中,注解广泛用于框架开发、代码生成和配置管理等方面,展示了其强大的功能和灵活性。
267 25
|
XML Java 编译器
Java学习十六—掌握注解:让编程更简单
Java 注解(Annotation)是一种特殊的语法结构,可以在代码中嵌入元数据。它们不直接影响代码的运行,但可以通过工具和框架提供额外的信息,帮助在编译、部署或运行时进行处理。
355 43
Java学习十六—掌握注解:让编程更简单
|
Java 数据库连接 Spring
反射-----浅解析(Java)
在java中,我们可以通过反射机制,知道任何一个类的成员变量(成员属性)和成员方法,也可以堆任何一个对象,调用这个对象的任何属性和方法,更进一步我们还可以修改部分信息和。
|
Java 编译器 数据库
Java 中的注解(Annotations):代码中的 “元数据” 魔法
Java注解是代码中的“元数据”标签,不直接参与业务逻辑,但在编译或运行时提供重要信息。本文介绍了注解的基础语法、内置注解的应用场景,以及如何自定义注解和结合AOP技术实现方法执行日志记录,展示了注解在提升代码质量、简化开发流程和增强程序功能方面的强大作用。
476 5
|
安全 Java 索引
Java——反射&枚举
本文介绍了Java反射机制及其应用,包括获取Class对象、构造方法、成员变量和成员方法。反射允许在运行时动态操作类和对象,例如创建对象、调用方法和访问字段。文章详细解释了不同方法的使用方式及其注意事项,并展示了如何通过反射获取类的各种信息。此外,还介绍了枚举类型的特点和使用方法,包括枚举的构造方法及其在反射中的特殊处理。
293 9
Java——反射&枚举
|
监控 Java
Java基础——反射
本文介绍了Java反射机制的基本概念和使用方法,包括`Class`类的使用、动态加载类、获取方法和成员变量信息、方法反射操作、以及通过反射了解集合泛型的本质。同时,文章还探讨了动态代理的概念及其应用,通过实例展示了如何利用动态代理实现面向切面编程(AOP),例如为方法执行添加性能监控。
193 5
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
|
Java
Java的反射
Java的反射。
186 2
|
安全 Java 测试技术
🌟Java零基础-反射:从入门到精通
【10月更文挑战第4天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
242 2