扫盲java基础-反射机制

一、反射怎么来的


在这里插入图片描述

二、例子


1、先写一个StudentDemo类

package com.weizhaoyang.Student;

public class StudentDemo{
private String username;
private Integer age;
private String sex;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}

}

2、在创建一个TestStudent的类
当我们创建好两个类的时候:编辑器软件就已经编译成了.class文件,不去运行也会编译成.class文件,因为编辑器里面配置了jdk。

package com.weizhaoyang.Student;

public class TestStudent {

}

在这里插入图片描述

3、创建StudentDemo的实例
当new的过程中,也就是运行期间,把上面的.class文件加载到java虚拟机上面,并且会得到一个Student类对应的类对象。

package com.weizhaoyang.Student;

public class TestStudent {
public static void main(String[] args) {

StudentDemo stu=new StudentDemo();
}
}

获取类对象:这个student就是类对象。

//这个方法是Object中的方法
Class student=stu.getClass();

说下怎么判断.class文件被加载到java虚拟机上?通过在一个类上加上静态块。
这个静态块执行:这个StudentDemo.class文件首次被加载到java虚拟机上才会执行。
在这里插入图片描述
再次运行下主函数:运行的结果如下,这时这个类文件就被加载到了jvm上了。在运行的时候就相当于用java命令执行类文件。java运行期才会把.class文件加载到jvm上运行。在这里插入图片描述
当我们不去new的时候,也会拿到类对象的,类对象也就是Class对象 。
这个类对象是由java虚拟机第一次加载字节码class文件的时候就自动的把这个对象创建了起来。

代码如下:
在这里插入图片描述
再证实下这个事实:代码如下,说明还没有new的时候这个类对象就已经加载到内存里面去了。class文件只是用的时候才会加载。new的时候才会分配内存。
在这里插入图片描述

总结:下面的图就是当一个类的主函数被压栈的时候,就可以拿到当前类的Class对象,从而把Student.class加载到jvm上,从而在内存中分配一块内存用来存储Class对象 ,而这个Class对象就可以获取到类里的成员变量,方法,和构造函数。

在这里插入图片描述
获取到类对象之后是不能操作类成员的,必须通过反射来操作,代码如下:
在这里插入图片描述

总结:平常是通过类的实例获取类的信息,而反射是通过类对象类获取类信息。 私有的方法通过反射的外部类来也可以去调用它。但是可以用匿名内部来保护类的安全。

欢迎各位小伙伴来咨询,想要工程源码的加群:797853299

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的生成器(generator)是一种特殊的迭代器,可以用来逐步生成序列。与普通函数不同,生成器函数使用yield关键字来返回值,而不是return。当函数执行到yield时,函数会暂停并将yield后面的值返回给调用者,但是函数的状态仍然保留在内存中,可以再次恢复执行。 以下是一些生成器的用法: 1. 生成器表达式 Python中的生成器表达式与列表推导式类似,但是使用圆括号而不是方括号。它可以用来生成一个序列,而不是一次性生成整个序列。 示例: ``` gen = (x * x for x in range(10)) for i in gen: print(i) ``` 2. yield语句 yield语句可以用来定义生成器函数。当函数执行到yield语句时,函数会暂停并将yield后面的值返回给调用者。函数的状态仍然保留在内存中,可以再次恢复执行。 示例: ``` def generator_func(): for i in range(10): yield i * i gen = generator_func() for i in gen: print(i) ``` 3. send方法 send方法可以在生成器函数中向生成器发送一个值,并继续执行生成器函数。这个值可以通过yield语句返回。 示例: ``` def generator_func(): while True: x = yield print(x) gen = generator_func() next(gen) gen.send(10) ``` 4. yield from语句 yield from语句可以用来在生成器函数中调用另一个生成器函数。它可以让代码更加简洁,并且能够处理嵌套生成器的情况。 示例: ``` def child_gen(): for i in range(5): yield i def parent_gen(): yield from child_gen() gen = parent_gen() for i in gen: print(i) ``` 以上是一些生成器的用法,希望对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值