2.prototype
prototype作用域的Bean,Spring只负责创建,当容器创建了Bean实例后,Bean的实例就交给客户端代码来管理,Spring容器将不再跟踪其生命周期。
容器只创建bean不管理,容器初始化时,不会创建bean,只有在获取时才会创建bean,spring 只负责创建,不持有bean,也不负责销毁,还可以为bean 配置 init()初始化方法,destroy() 销毁方法
public class Student implements Serializable {
private int id;
private String name;
/**
- 初始化 资源
*/
public void init(){
System.out.println(“Student 初始化方法”);
}
/**
- 释放资源
*/
public void destroy(){
System.out.println(“Student 销毁方法”);
}
。。。。
}
<?xml version="1.0" encoding="UTF-8"?><beans xmlns=“http://www.springframework.org/schema/beans”
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation=“http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd”>
<bean id=“student1” class=“com.qfedu.entity.Student” scope=“singleton”
init-method=“init” destroy-method=“destroy”>
<bean id=“student2” class=“com.qfedu.entity.Student” scope=“prototype”
init-method=“init” destroy-method=“destroy”>
测试:
/**
*bena的生命周期
*/
public class LifeTest {
public static void main(String[] args) {
ClassPathXmlApplicationContext classPathXmlApplicationContext = new ClassPathXmlApplicationContext(“life/life_bean.xml”);
Student student1 = (Student) classPathXmlApplicationContext.getBean(“student1”);
System.out.println(student1);
System.out.println(“容器销毁”);
// 明示销毁容器,此时会调用容器中所有bean destroy() 方法
// 单例bean 调用 destroy()
// 原型bean 不会调用 destroy() 因为容器不持有该bean
classPathXmlApplicationContext.destroy();
}
}
什么Bean的装配? 就是bean 属性的设置,以及bean 之间依赖关系的配置
1.基于XML的装配
property和构造方法设置值(无参和有参)
<?xml version="1.0" encoding="UTF-8"?><beans xmlns=“http://www.springframework.org/schema/beans”
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation=“http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd”>
Java
UI
H5
php
Java
UI
H5
php
2.测试
public class XmlTest {
public static void main(String[] args) {
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(“xml/xml_bean.xml”);
Student student1 = (Student) applicationContext.getBean(“student1”);
System.out.println("student1 = " + student1);
Student student2 = (Student) applicationContext.getBean(“student2”);
System.out.println("student2 = " + student2);
}
}
注解:就是一个标记,记号,通过注解创建bean 并管理bean 之间的依赖关系
注入的注解,一个实例中的属性可以通过以下注解从容器获取对应的bean,并注入进来:
@Autowired:用于对Bean的属性变量、属性的setter方法及构造方法进行标注,配合对应的注解处理器完成Bean的自动配置工作
@Qualifier:与@Autowired注解配合使用,会将默认的按Bean类型装配修改为按Bean的实例名称装配,Bean的实例名称由@Qualifier注解的参数指定。
@Resource:其作用与Autowired一样。@Resource中有两个重要属性:name和type。Spring将name属性解析为Bean实例名称,type属性解析为Bean实例类型。
1.@Autowired + @Qualifier
激活注入的注解:
context:annotation-config</context:annotation-config>
加入注解到容器中:
装配:
public class StudentServiceImpl implements StudentService{
/*@Autowired 不需要 setter方法支持
-
意义: 1.首先根据注解的类型 去容器中查找 如果只有一个,则设置
-
2.如果按照类型查找到 多个 ,则使用 变量名( private StudentDao studentDao) 作为id 去容器中查找 -
3.如果按照变量名找不到,可以使用@Qualifier("studentDao2") 配置,按照传递的参数作为iD 查找
*/
// 去容器中查找 StudentDao 对应实例,并将当前 属性引用
@Autowired
@Qualifier(“studentDao2”)//如果找到多个使用 @Qualifier区分
private StudentDao studentDao;
// public void setStudentDao(StudentDao studentDao){
// this.studentDao = studentDao;
// }
public Student findStudentById(int id) {
return studentDao.findStudentById(id);
}
}
2.@Resource
激活注入的注解:
context:annotation-config</context:annotation-config>
加入注解到容器中:
装配:
public class StudentServiceImpl implements StudentService{
/*
-
@Resource 也是 将容器中的bean 注入到当前对象中
-
意义:
-
1.首先按照声明 属性名作为id 去容器中查找(private StudentDao studentDao ), -
2.如果没有找到 按照类型查找 ,如果查找到一个则设置值, 如果查到多个,则进入第三步 -
3.@Resource(name = "studentDao2"): 如果找到多个类型的bean 必须传入name 作为id 进行限定 -
@Autowired @Resource 的区别?
-
- @Resource(name = “studentDao2”) 等价于 @Autowired @Qualifier
-
2.意义
-
3.@Resource 是jdk 注解 @Autowired 是spring 注解
-
*/
@Resource(name = “studentDao2”)
private StudentDao studentDao;
// public void setStudentDao(StudentDao studentDao){
// this.studentDao = studentDao;
// }
public Student findStudentById(int id) {
return studentDao.findStudentById(id);
}
}
1.@Autowired 不需要 setter方法支持
意义:
1.首先根据注解的类型 去容器中查找 如果只有一个,则设置
2.如果按照类型查找到 多个 ,则使用 变量名( private StudentDao studentDao) 作为id 去容器中查找
3.如果按照变量 名找不到,可以使用@Qualifier(“studentDao2”) 配置,按照传递的参数作为iD 查找
2.@Resource 也是 将容器中的bean 注入到当前对象中
意义:
1.首先按照声明 属性名作为id 去容器中查找(private StudentDao studentDao )
2.如果没有找到 按照类型查找 ,如果查找到一个设置值 如果多个,则进入第三部
3.@Resource(name = “studentDao2”) 如果找到多个类型的bean 必须传入name 作为id 进行限定
3.@Autowired @Resource 的区别?
1.@Resource(name = “studentDao2”) 等价于 @Autowired @Qualifier
2.@Resource 是jdk 注解 @Autowired spring 注解
@Component//@Component // 在容器中加入bean 默认id studentServiceImpl
@Component(“studentService”) // 在容器中加入bean id studentService以下三个用法和 @Component 一样是@Component 的子注解
@Service 用于service@Controller 用于控制层
@Repository 用于持久层 dao

<beans xmlns=“http://www.springframework.org/schema/beans”
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”
xmlns:context=“http://www.springframework.org/schema/context”
xsi:schemaLocation=“http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd”>
<context:component-scan base-package=“com.qfedu”></context:component-scan>
//@Component // 在容器中加入bean 默认id studentServiceImpl
//@Component(“studentService”) // 在容器中加入bean id studentService
@Service(“studentService”)// 加入到容器 id studentService
public class StudentServiceImpl implements StudentService {
// 去容器中查找 StudentDao 对应实例,并将当前 属性引用
/**
-
@Autowired 不需要 setter方法支持
-
意义: 1.首先根据注解的类型 去容器中查找 如果只有一个,则设置
-
2.如果按照类型查找到 多个 ,则使用 变量名( private StudentDao studentDao) 作为id 去容器中查找 -
3.如果按照变量 名找不到,可以使用@Qualifier("studentDao2") 配置,按照传递的参数作为iD 查找 -
@Resource 也是 将容器中的bean 注入到当前对象中
-
意义:
-
1.首先按照声明 属性名作为id 去容器中查找(private StudentDao studentDao ), -
2.如果没有找到 按照类型查找 ,如果查找到一个设置值 如果多个,则进入第三部 -
3.@Resource(name = "studentDao2") 如果找到多个类型的bean 必须传入name 作为id 进行限定 -
@Autowired @Resource 的区别?
-
- @Resource(name = “studentDao2”) 等价于 @Autowired @Qualifier
-
2.意义
-
3.@Resource 是jdk 注解 @Autowired spring 注解
*/
// @Autowired
// @Qualifier(“studentDao2”)//如果找到多个使用 @Qualifier区分
@Resource
private StudentDao studentDao ;
// public void setStudentDao(StudentDao studentDao) {
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。


既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
Kafka实战笔记
关于这份笔记,为了不影响大家的阅读体验,我只能在文章中展示部分的章节内容和核心截图

- Kafka入门
- 为什么选择Kafka
- Karka的安装、管理和配置

- Kafka的集群
- 第一个Kafka程序

afka的生产者

- Kafka的消费者
- 深入理解Kafka
- 可靠的数据传递


- Spring和Kalka的整合
- Sprinboot和Kafka的整合
- Kafka实战之削峰填谷
- 数据管道和流式处理(了解即可)

- Kafka实战之削峰填谷

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
Kafka实战笔记
关于这份笔记,为了不影响大家的阅读体验,我只能在文章中展示部分的章节内容和核心截图
[外链图片转存中…(img-Vis3ywvZ-1712412363907)]
- Kafka入门
- 为什么选择Kafka
- Karka的安装、管理和配置
[外链图片转存中…(img-3oJF33Fp-1712412363908)]
- Kafka的集群
- 第一个Kafka程序
- [外链图片转存中…(img-qQc5o9Gr-1712412363908)]
afka的生产者
[外链图片转存中…(img-hvc8HrtY-1712412363908)]
- Kafka的消费者
- 深入理解Kafka
- 可靠的数据传递
[外链图片转存中…(img-D94LE5J9-1712412363909)]
[外链图片转存中…(img-DdYKTE6w-1712412363909)]
- Spring和Kalka的整合
- Sprinboot和Kafka的整合
- Kafka实战之削峰填谷
- 数据管道和流式处理(了解即可)
[外链图片转存中…(img-7PeVZeSH-1712412363909)]
- Kafka实战之削峰填谷
[外链图片转存中…(img-C4mRfVH8-1712412363909)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
本文详细介绍了Spring框架中Bean的两种作用域(singleton和prototype),重点讲解了原型模式下Bean的创建和管理,以及基于XML和注解的装配方式,包括@Autowired、@Qualifier和@Resource的使用。还涉及了Spring与Kafka的集成和SpringBoot中的Bean生命周期管理。

1万+

被折叠的 条评论
为什么被折叠?



