【Spring系列】- Bean生命周期底层原理


上次学到动手模拟Spring底层实现,简单学习了一下Spring,对spring有所了解,接着就来分析spring中bean的生命周期的步步流程。

1|2流程

接下来会根据Bean生命周期一步一步去学习,spring在创建bean对象的过程中,还是做了许多的操作,从依赖注入,通过初始化以及前后操作,最后创建了bean对象放入Map单例池,对于多例是不放进去的。
本次实验使用的pom依赖

<dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.3.15</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aspects</artifactId> <version>5.3.15</version> </dependency>

1|3依赖注入

首先是根据无参构造方法去获取对象,通过这个类获取所有字段,在来判断是否有Autowired注解,在给这个属性去赋值。

UserService userService1 = new UserService(); for (Field field : userService1.getClass().getDeclaredFields()) { if (field.isAnnotationPresent(Autowired.class)) { field.set(userService1, ???); } }

1|4初始化前执行方法

通过对象获取所有方法,我们在需要执行的方法上使用PostConstruct注解,然后就只需要遍历这些方法,去判断是否含有这个注解,在使用invoke去执行方法。

for (Method method : userService1.getClass().getMethods()) { if (method.isAnnotationPresent(PostConstruct.class)) { method.invoke(userService1, null); } }

1|5初始化

       除了使用PostConstruct注解去执行方法,还有一种方法是通过去实现InitializingBean接口,并且需要实现其未实现的方法afterPropertiesSet。
       那么对象是如何知道在spring中会有afterPropertiesSet这个方法呢?可以通过反射判断是否有这个方法,有的话就直接执行。在spring中,他是采用去判断对象是否有实现InitializingBean这个类,有的话会强转成这个类,再去执行这个类的方法

1|6推断构造方法底层原理

       如果有多个构造方法,回去寻找是否有无参的,找到了,就直接使用,没找到就会报错。如果是使用了多个构造方法,可以使用Autowired去告诉spring需要使用那个构造方法。如果在构造方法里需要一个bean对象,那么spring会去map单例池中去查找相应的bean对象,如果没找到,就会去创建bean对象,但如果是多例bean的话,就不需要查找,直接创建一个对象。
当我们使用构造方法获取bean对象时,一般是通过类上使用Component注解去定义一个首位字母小写的bean对象,也可以是通过Bean注解,去创建不同bean名的相同类型的bean对象。
        如下代码,在配置中添加两个bean对象,包括类上自己生成的一共三个bean对象。分别为{roleServiceroleService1roleService2}。这三个的类型一样,但是对象是不同的,名字不同,bean对象就不同。

@ComponentScan("com.lyd") public class ApplicationConfig { @Bean public RoleService roleService1() { return new RoleService(); } @Bean public RoleService roleService2() { return new RoleService(); } }

当使用其中一个beanName都是可以的

@Component public class UserService { private RoleService roleService; public UserService(RoleService roleService1) { this.roleService = roleService1; } public void test(){ System.out.println(roleService); } }

但是如果使用的不是上面三个其中之一,就会报错。但是能看到他找到了三个。

1|7AOP – 动态代理

使用AOP就是需要使用代理对象,然而代理对象与第一次的对象是不一样的。
首先定义一个aop切面

本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;

2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;

3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;

4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;

5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/293329.html

(0)
上一篇 2022年11月20日
下一篇 2022年11月20日

相关推荐

发表回复

登录后才能评论