侧边栏壁纸
博主头像
高大北博主等级

所有的再见中,我最喜欢明天见

  • 累计撰写 208 篇文章
  • 累计创建 151 个标签
  • 累计收到 20 条评论
标签搜索

目 录CONTENT

文章目录

Java Reflection初识

高大北
2022-05-05 / 0 评论 / 1 点赞 / 268 阅读 / 1,459 字 / 正在检测是否收录...

反射概念

1.Reflection(反射)是Java被视为动态语言的关键,反射机制允许程序在执行期借助于ReflectionAPI取得任何类的内部信息,并能直接操作任意对象的内部属性及方法
2. 加载完类之后,在堆内存的方法区中就产生了一个Class类型的对象(一个类只有一个Class对象),这个度对象就包含了完整的类的结构信息。我们可以通过这个对象看到类的结构。

  • 正常方式:引入需要的"包类"名称>通过new实例化>取得实例化对象
  • 反射方式:实例化对象>getClass()方法>得到完整的"包类"名称

示?

public class Test01 {
    public static void main(String[] args) throws ClassNotFoundException {
        //通过反射获取类的Class对象
        Class<?> c1 = Class.forName("com.fl.reflection.User");
        Class<?> c2= Class.forName("com.fl.reflection.User");
        Class<?> c3 = Class.forName("com.fl.reflection.User");
        Class<?> c4 = Class.forName("com.fl.reflection.User");
        System.out.println(c1);
        /**
         * c2、 c3、c4 hashCode值相同
         * 1.一个类在内存中只有一个Class对象
         * 2.一个类被加载后,类的整个结构都会被封装在class对象中
         */
        System.out.println(c2.hashCode());
        System.out.println(c3.hashCode());
        System.out.println(c4.hashCode());
        
        User user = new User();
        Class<? extends User> aClass = user.getClass();
        System.out.println(aClass);
    }
}
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 +
                '}';
    }
}

1

评论区