Spring bean为什么需要依赖注入
具体步骤:
1.创建一个maven项目 spring-day1-constructor
2.导入依赖
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <!--这里是java 版本号--> <maven.compiler.source>11</maven.compiler.source> <maven.compiler.target>11</maven.compiler.target> <!--这里是方便版本控制--> <spring.version>5.3.1</spring.version> <lombok.version>1.18.20</lombok.version> <junit.version>4.12</junit.version> </properties> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>${lombok.version}</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>${junit.version}</version> </dependency> </dependencies>
3.工程项目结构
样例1:
1.创建一个Student类
public class Student { private Long number; private String name; private String school; public void setNumber(Long number) { this.number = number; } public void setName(String name) { this.name = name; } public void setSchool(String school) { this.school = school; } public Student() { } public Student(Long number, String name, String school) { this.number = number; this.name = name; this.school = school; } @Override public String toString() { return "Student{" + "number=" + number + ", name='" + name + '\'' + ", school='" + school + '\'' + '}'; } }
写一个配置文件
<?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="s1" class="com.crush.pojo.Student"> <constructor-arg index="0" value="12"/> <constructor-arg index="1" value="wyh"/> <constructor-arg index="2" value="北大"/> </bean> <!--这里是根据构造函数中的 类型来进行注入 --> <bean id="s2" class="com.crush.pojo.Student"> <constructor-arg type="java.lang.Long" value="123"/> <constructor-arg type="java.lang.String" value="crush"/> <constructor-arg type="java.lang.String" value="浙江大学"/> </bean> </beans>
3.测试
@org.junit.Test public void testStudent(){ ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml"); Student student = applicationContext.getBean("s2", Student.class); System.out.println(student); }
样例2:
1.创建Teacher类
public class Teacher { private String name; private String school; private List<Student> studentList; private Map<String,String> map; private Set<String> set; public Teacher(String name, String school, List<Student> studentList, Map<String, String> map, Set<String> set) { this.name = name; this.school = school; this.studentList = studentList; this.map = map; this.set = set; } @Override public String toString() { return "Teacher{" + "name='" + name + '\'' + ", school='" + school + '\'' + ", studentList=" + studentList + ", map=" + map + ", set=" + set + '}'; } }public class Teacher { private String name; private String school; private List<Student> studentList; private Map<String,String> map; private Set<String> set; public Teacher(String name, String school, List<Student> studentList, Map<String, String> map, Set<String> set) { this.name = name; this.school = school; this.studentList = studentList; this.map = map; this.set = set; } @Override public String toString() { return "Teacher{" + "name='" + name + '\'' + ", school='" + school + '\'' + ", studentList=" + studentList + ", map=" + map + ", set=" + set + '}'; } }
2.beans.xml
<bean id="teacher" class="com.crush.pojo.Teacher"> <constructor-arg index="0" value="xxx"/> <constructor-arg index="1" value="北京大学"/> <constructor-arg index="2" > <list> <ref bean="s1"/> <ref bean="s2"/> </list> </constructor-arg> <constructor-arg index="3"> <map> <entry key="k1" value="xiaowang"/> </map> </constructor-arg> <constructor-arg index="4"> <set> <value>1</value> <value>2</value> </set> </constructor-arg> </bean>
3.测试
@org.junit.Test public void testTeacher(){ ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml"); Teacher teacher = applicationContext.getBean("teacher", Teacher.class); System.out.println(teacher); }
Spring单例模式和原型模式
一、单例模式
Spring默认是单例模式的。
以Student的那个样例1 为例。 scope=“singleton” 加上这么一个设置 当然默认也是它。
bean id="s1" class="com.crush.pojo.Student" scope="singleton"> <constructor-arg index="0" value="12"/> <constructor-arg index="1" value="wyh"/> <constructor-arg index="2" value="北大"/> </bean>
这个时候我们来进行测试
@org.junit.Test public void testStudent(){ ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml"); Student student1 = applicationContext.getBean("s1", Student.class); Student student2 = applicationContext.getBean("s1", Student.class); // 并且如果我们对其中一个做了修改 ,其余也会跟着一起被修改 // 可以看到我们只修改了一个 student1.setSchool("梦中的学校"); System.out.println(student1); System.out.println(student2); System.out.println(student1==student2); }
二、原型模式
我们还是以**Student来做例子讲解 ** 注意:我们把原来设置改成了 scope=“prototype” 也就是原型模式
<!--这里是根据构造函数中的 类型来进行注入 --> <bean id="s2" class="com.crush.pojo.Student" scope="prototype"> <constructor-arg type="java.lang.Long" value="123"/> <constructor-arg type="java.lang.String" value="crush"/> <constructor-arg type="java.lang.String" value="浙江大学"/> </bean>
接着测试
@org.junit.Test public void testStudent(){ ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml"); Student student1 = applicationContext.getBean("s2", Student.class); Student student2 = applicationContext.getBean("s2", Student.class); // 并且如果我们对其中一个做了修改 ,其余也会跟着一起被修改 // 可以看到我们只修改了一个 student1.setSchool("梦中的学校"); System.out.println(student1); System.out.println(student2); System.out.println(student1==student2); }
思考 为什么需要依赖注入
为什么我们以前用一个对象 new一下就好了,但用了Spring 之后,反而还需要写
这样一段代码再去获取勒?明明感觉更麻烦啦丫?用这个又有什么样的好处呢?
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml"); Student student1 = applicationContext.getBean("s2", Student.class);
总结
本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注猪先飞的更多内容!
相关文章
- PHPEMS(PHP Exam Management System)在线模拟考试系统基于PHP+Mysql开发,主要用于搭建模拟考试平台,支持多种题型和展现方式,是国内首款支持题冒题和自动评分与教师评分相...2016-11-25
- SQL注入攻击指的是通过构建特殊的输入作为参数传入Web应用程序,而这些输入大都是SQL语法里的一些组合,通过执行SQL语句进而执行攻击者所要的操作 标准注入语句1.判...2016-11-25
- 这篇文章主要介绍了Spring AOP 对象内部方法间的嵌套调用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-08-29
- 防止SQL注入是我们程序开发人员必须要做的事情了,今天我们就来看一篇关于PHP防止SQL注入的例子了,具体的实现防过滤语句可以参考下面来看看吧。 使用prepared以及参...2016-11-25
Spring Cloud 中@FeignClient注解中的contextId属性详解
这篇文章主要介绍了Spring Cloud 中@FeignClient注解中的contextId属性详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-25Springboot如何实现Web系统License授权认证
这篇文章主要介绍了Springboot如何实现Web系统License授权认证,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-05-28- 这篇文章主要介绍了详解SpringCloudGateway内存泄漏问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-07-16
如何在Spring WebFlux的任何地方获取Request对象
这篇文章主要介绍了如何在Spring WebFlux的任何地方获取Request对象,帮助大家更好的理解和使用springboot框架,感兴趣的朋友可以了解下...2021-01-26- @Autowired 注解的主要功能就是完成自动注入,使用也非常简单,但这篇文章主要给大家介绍了关于Spring为什么不推荐使用@Autowired注解的相关资料,需要的朋友可以参考下...2021-11-03
Springboot如何使用mybatis实现拦截SQL分页
这篇文章主要介绍了Springboot使用mybatis实现拦截SQL分页,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-19- 本文主要介绍AngularJS 依赖注入的知识,这里整理了相关的基础知识,并附示例代码和实现效果图,有兴趣的小伙伴可以参考下...2016-08-24
- 这篇文章主要介绍了SpringMVC文件上传原理及实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-07-15
Spring Data JPA 关键字Exists的用法说明
这篇文章主要介绍了Spring Data JPA 关键字Exists的用法说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-06-10- SQL注入攻击是黑客攻击网站最常用的手段。如果你的站点没有使用严格的用户输入检验,那么常容易遭到SQL注入攻击。SQL注入攻击通常通过给站点数据库提交不良的数据或...2016-11-25
tomcat启动完成执行 某个方法 定时任务(Spring)操作
这篇文章主要介绍了tomcat启动完成执行 某个方法 定时任务(Spring)操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-25- 这篇文章主要介绍了Springboot实现多线程注入bean的工具类操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-08-27
使用Maven 搭建 Spring MVC 本地部署Tomcat的详细教程
这篇文章主要介绍了使用Maven 搭建 Spring MVC 本地部署Tomcat,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-08-16- 这篇文章主要介绍了Spring Cloud负载均衡及远程调用实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2021-09-18
- 这篇文章主要介绍了SpringMvc自动装箱及GET请求参数原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-19
- 这篇文章主要介绍了SpringMvc获取请求头请求体消息过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-17