平常的Java开发中,程序员在某个类中需要依赖其它类的方法。

通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理。

Spring提出了依赖注入的思想,即依赖类不由程序员实例化,而是通过Spring容器帮我们new指定实例并且将实例注入到需要该对象的类中。

依赖注入的另一种说法是"控制反转"。通俗的理解是:平常我们new一个实例,这个实例的控制权是我们程序员。

而控制反转是指new实例工作不由我们程序员来做而是交给Spring容器来做。

1.Set注入

构建一个Student对象

package cn.happy.entity;

/**
* Created by CKW on 2017/3/19.
*/
public class Student {
private String sname;
private Integer sage; public Integer getSage() {
return sage;
} public void setSage(Integer sage) {
this.sage = sage;
} public String getSname() {
return sname;
} public void setSname(String sname) {
this.sname = sname;
} }

在配置applicationContext.xml中:

    <!--set 注入  prototype  原型   singletion  单例-->
<bean id="stu" class="cn.happy.entity.Student" scope="prototype">
<property name="sname" value="张三"></property>
<property name="sage" value=""></property>
</bean>

测试类中:

    //被Spring管理的bean默认都是单例的
@Test
public void myTest1(){
//ac 就是Spring容器
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
Student stu=(Student) ac.getBean("stu");
Student stu1=(Student) ac.getBean("stu");
System.out.println(stu+"\n"+stu1);
}

2.构造器注入

在对象中添加构造

配置中:

    <!--构造注入-->
<bean id="car1" class="cn.happy.entity.Car">
<property name="cname" value="图驴子"></property>
</bean>
<bean id="stu1" class="cn.happy.entity.Student">
<!--()创建构造器注入,如果主类有带参的构造方法则需添加此配置-->
<constructor-arg index="" value="哇哈哈"></constructor-arg>
<constructor-arg index="" value=""></constructor-arg>
<constructor-arg index="" ref="car1"></constructor-arg>
</bean>

测试类:

    //构造注入
@Test
public void myTest2(){
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
Student stu1=(Student) ac.getBean("stu1");
Student stu2=(Student) ac.getBean("stu2");
System.out.println("构造:"+stu1); }

3.空间命名注入

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:p="http://www.springframework.org/schema/p"
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/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
">
    <!--命名空间P注入-->
<bean id="car2" class="cn.happy.entity.Car">
<property name="cname" value="毛驴"></property>
</bean>
<bean id="stu2" class="cn.happy.entity.Student" p:sname="李四" p:sage="" p:car-ref="car2"></bean>
    //构造注入   命名空间注入
@Test
public void myTest2(){
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
Student stu1=(Student) ac.getBean("stu1");
Student stu2=(Student) ac.getBean("stu2");
System.out.println("构造:"+stu1+"\n命名空间:"+stu2); }

4.集合注入

    <!--list集合属性注入-->
<bean id="collection1" class="cn.happy.entity.MyCollection">
<property name="list">
<list>
<value>哈哈</value>
<value>呵呵</value>
<value>嘿嘿</value>
</list>
</property>
</bean> <!--set集合属性注入-->
<bean id="collection2" class="cn.happy.entity.MyCollection">
<property name="set">
<set>
<value>哈哈</value>
<value>呵呵</value>
<value>嘿嘿</value>
</set>
</property>
</bean> <!--Map集合属性注入-->
<bean id="collection3" class="cn.happy.entity.MyCollection">
<property name="map">
<map>
<entry key="">
<value>呵呵</value>
</entry>
<entry key="">
<value>哈哈</value>
</entry>
<entry key="">
<value>嘿嘿</value>
</entry>
</map>
</property>
</bean>

5.注解注入

package cn.happy.entity;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Controller;
import org.springframework.stereotype.Repository;
import org.springframework.stereotype.Service; /**
* Created by CKW on 2017/3/22.
*/
@Component("car") //不分层
/*@Repository //dao层*/
/*@Service //biz层*/
/*@Controller //action层*/
public class Car {
@Value("特斯拉")
private String cname; @Override
public String toString() {
return getCname();
} public Car() {
} public Car(String cname) {
this.cname = cname;
} public String getCname() {
return cname;
} public void setCname(String cname) {
this.cname = cname;
}
}
package cn.happy.entity;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component; import javax.annotation.Resource; /**
* Created by CKW on 2017/3/22.
*/ @Component("student")
public class Student {
@Value("撒打发")
private String sname;
@Value("")
private Integer sage;
//jdk注解
// @Resource
@Autowired
@Qualifier("car")
private Car car; @Override
public String toString() {
return "name="+getSname()+",age="+getSage()+",car="+getCar();
} public Car getCar() {
return car;
} public void setCar(Car car) {
this.car = car;
} public Student() { } public String getSname() {
return sname;
} public Student(String sname, Integer sage, Car car) {
this.sname = sname;
this.sage = sage;
this.car = car;
} public void setSname(String sname) {
this.sname = sname;
} public Integer getSage() {
return sage;
} public void setSage(Integer sage) {
this.sage = sage;
}
}

在配置applicationContext.xml中:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:p="http://www.springframework.org/schema/p"
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/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
">
  <!--注解-->
<!--配置包扫描器-->
<context:component-scan base-package="cn.happy.entity"></context:component-scan>

测试类:

    //注解
@Test
public void myTest4(){
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
Student stu=(Student)ac.getBean("student");
System.out.println(stu.getCar().getCname());
}

Spring多种方式实现依赖注入的更多相关文章

  1. Spring——多种方式实现依赖注入

    在Spring的XML配置中,只有一种声明bean的方式:使用<bean>元素并指定class属性.Spring会从这里获取必要的信息来创建bean. 但是,在XML中声明DI时,会有多种 ...

  2. IOC和AOP使用扩展 多种方式实现依赖注入

    多种方式实现依赖注入 1.Spring 使用setter访问器实现对属性的赋值, 2.Spring 构造constructor方法赋值, 3.接口注入 4.Spring P命名空间注入直接量 sett ...

  3. Spring - lookup-method方式实现依赖注入

    引言 假设一个单例模式的bean A需要引用另外一个非单例模式的bean B,为了在我们每次引用的时候都能拿到最新的bean B,我们可以让bean A通过实现ApplicationContextWa ...

  4. 多种方式实现依赖注入及使用注解定义bean

    构造注入 如何给构造方法中的参数注入方法呢如下 首先bean代码如下 package cn.pojo; public class Greeting { /** * 说的话 */ private Str ...

  5. Ioc和Aop扩展--多种方式实现依赖注入(构造注入,p命名空间注入,集合类型注入,注入null和注入空值)

    构造注入 语法: <constructor-arg>    <ref bean="bean的id"/> </constructor-arg> 1 ...

  6. Spring源码剖析依赖注入实现

    Spring源码剖析——依赖注入实现原理 2016年08月06日 09:35:00 阅读数:31760 标签: spring源码bean依赖注入 更多 个人分类: Java   版权声明:本文为博主原 ...

  7. (转)Spring读书笔记-----Spring核心机制:依赖注入

    Java应用(从applets的小范围到全套n层服务端企业应用)是一种典型的依赖型应用,它就是由一些互相适当地协作的对象构成的.因此,我们说这些对象间存在依赖关系.加入A组件调用了B组件的方法,我们就 ...

  8. 回客科技 面试的 实现ioc 容器用到的技术,简述BeanFactory的实现原理,大搜车面试的 spring 怎么实现的依赖注入(DI)

    前言:这几天的面试,感觉自己对spring 的整个掌握还是很薄弱.所以需要继续加强. 这里说明一下spring的这几个面试题,但是实际的感觉还是不对的,这种问题我认为需要真正读了spring的源码后说 ...

  9. ExpandoObject与DynamicObject的使用 RabbitMQ与.net core(一)安装 RabbitMQ与.net core(二)Producer与Exchange ASP.NET Core 2.1 : 十五.图解路由(2.1 or earler) .NET Core中的一个接口多种实现的依赖注入与动态选择看这篇就够了

    ExpandoObject与DynamicObject的使用   using ImpromptuInterface; using System; using System.Dynamic; names ...

随机推荐

  1. 洛谷P5173 传球(暴力)

    传送门 真·暴力艹过去 不难发现这个转移其实就是一个循环卷积的形式,设有多项式\(A=x+x^{n-1}\),那么\(f_m=f_0\times A^m\) 直接暴力计算并卡常就行了 //minamo ...

  2. [Xcode 实际操作]七、文件与数据-(10)NSkeyedArchiver存储和解析数据,Swift对象的归档和恢复归档

    目录:[Swift]Xcode实际操作 本文将演示如何使用归档的方法,对模型对象进行持久化工作. 在项目名称上点击鼠标右键,弹出右键菜单,选择[New File]新建文件命令, 在弹出的模板选项窗口中 ...

  3. [Xcode 实际操作]七、文件与数据-(4 )遍历文件夹中的文件

    目录:[Swift]Xcode实际操作 本文将演示如何遍历文件夹下的内容. 在项目导航区,打开视图控制器的代码文件[ViewController.swift] import UIKit class V ...

  4. 基于testcontainers的现代化集成测试进阶之路

    大型的软件工程项目除了大量的产品级代码外必不可少的还有大量的自动化测试.自动化测试包含从前端到后端甚至到产品线上不同模块和环境的各种类型的测试.一个比较经典的关于自动化测试分布的理论就是测试金字塔,是 ...

  5. openinstall渠道统计工具介绍

    大家好,今天给大家介绍一下如何使用openinstall 来实现APP 渠道统计,做运营推广的朋友应该对渠道统计并不陌生,之前一般都是让技术的同事打渠道包方式进行渠道统计,而且只有安卓才能打渠道包.o ...

  6. Postgresql 10 自带扩展模块功能说明

    adminpackadminpack提供了许多支持功能,pgAdmin 和其他管理和管理工具可以使用它们来提供其他功能,例如远程管理服务器日志文件.所有这些功能的使用仅限于超级用户. citext 该 ...

  7. 2.关键字global,nonlocal

    count=0 def func(): print(count) count+=1 func() UnboundLocalError: local variable 'count' reference ...

  8. jsp学习与提高(一)——JSP生命周期、三大指令及动作

    1.jsp定义: 1.1以java语言为脚本语言,运行在服务端的程序: 1.2处理客户请求,生成页面 1.3其本质是个sevlet会生成.java文件编译后再生成.class文件 2.jsp生命周期( ...

  9. 定位之float 同一父元素的float相互影响,float是margin盒子在父元素的padding盒子内

  10. 1、CreateJS介绍-EaselJS

    需要在html5文件中引入的CreateJS库文件是easeljs-0.7.1.min.js HTML5文件如下: <!DOCTYPE html> <html lang=" ...