Java的反射机制可以说是在Spring中发挥的淋漓尽致,下面要看的代码就是通过反射机制来实现向一个类注入其实际依赖的类型,这个过程的实现会交由Spring容器来帮我们完成。
JavaBean中针对属性一般都有一组设置/获取方法(setXXX/getXXX),这两个方法可以由IDE给我们自动产生,当然你也可以手动进行编写,这是你的自由,下面的例子就是Spring中利用setter方法来实现依赖注入。
源代码如下:
package com.pp;
//一个普通的JavaBean
public class Person {
//人的名字
private String S_name;
private String S_addr;
private int age;
//getter方法
public int getS_Age() {
return age;
}
//setter方法
public void setS_Age(int age) {
this.age = age;
}
//setter方法
public String getaddr() {
return S_addr;
}
//getter方法
public void setaddr(String addr) {
S_addr = addr;
}
//构造函数
public Person(){}
//getter方法
public String getName() {
return S_name;
}
//setter方法
public void setName(String name) {
S_name = name;
};
}
有了这个普通的JavaBean,我们要利用Spring容器来实现属性的注入,这里就需要Spring的配置文件,Spring的配置文件如下:
<?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:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id="sentence" class="com.pp.Sentence"/>
<bean id="person" class="com.pp.Person">
<!-- 从这里可以看出的是属性名是setter方法里去掉set的部分,即setXXX中的XXX而与具体的属性无关 -->
<property name="name" value="pptest"></property>
<!-- 这里你完全可以把setaddr里的参数改成setaddr(String name),并不会报错,因为判断的依据是setXXX即XXX -->
<!-- 但如果你改成setS_addr这里就要错了,不信你可以试,如果改成setS_addr,则下面的name需要改成S_addr -->
<property name="addr" value="Beijing"></property>
<!-- 这里就是上面的一个例子,类的属性名为age,但这里的name却为S_Age -->
<!-- 同时这里也要说明的一个问题是类里面为int,但这里却是字符串类型,这个你不用担心,Spring在进行注入时会自动根据参数的类型进行类型 的转化 -->
<property name="S_Age" value="22"></property>
</bean>
</beans>
配置文件中我已经注释的很清楚了,就不做说明了
下面是一个测试文件
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.ClassPathResource;
public class MainTest {
public static void main(String[] args) {
BeanFactory factory=new XmlBeanFactory(new ClassPathResource("person.xml"));
Person person=(Person)factory.getBean("person");
System.out.println(person.getName());
System.out.println(person.getaddr());
System.out.println(person.getS_Age());
}
}
如果一切正常的话,应该会打印出如下的结果:
pptest
Beijing
22
上面向类里面注入的均是内置类型,其实不仅可以注入内置类型,还可以向里面注入外部类对象,下面就是一个例子,只显示增加的部份,增加的部分,是假设每一个人均有说一句话,这句话的实际内容是由Sentence这个类决定的
源代码:
//这是一个普通的类,当然这样设计不好,在此仅为说明一下
public class Sentence{
//类里面的方法,表示每一个人均说的是同样的一句话
public void say() {
System.out.println("Hello");
}
}
下面是在类Person使用刚才的Sentence这个类,以下只列出新增代码
//代表要说的话
private Sentence sce;
//setter方法
public Sentence getSce() {
return sce;
}
//getter方法
public void setSce(Sentence sce) {
this.sce = sce;
}
以下是配置文件,同样也只列出新增的一部份
<bean id="sentence" class="com.pp.Sentence"/>
<bean id="person" class="com.pp.Person">
<!-- 从这里可以看出的是属性名是setter方法里去掉set的部分,即setXXX中的XXX而与具体的属性无关 -->
<property name="name" value="pptest"></property>
<!-- 这里你完全可以把setaddr里的参数改成setaddr(String name),并不会报错,因为判断的依据是setXXX即XXX -->
<!-- 但如果你改成setS_addr这里就要错了,不信你可以试,如果改成setS_addr,则下面的name需要改成S_addr -->
<property name="addr" value="Beijing"></property>
<!-- 这里就是上面的一个例子,类的属性名为age,但这里的name却为S_Age -->
<!-- 同时这里也要说明的一个问题是类里面为int,但这里却是字符串类型,这个你不用担心,Spring在进行注入时会自动根据参数的类型进行类型 的转化 -->
<property name="S_Age" value="22"></property>
<!-- 引入在外部定义的bean,这里就是上面的一个bean的id -->
<property name="Sce" ref="sentence"></property>
</bean>
测试文件里里面只需填加一行即可:
person.getSce().say();
最终的结果如下:
pptest
Beijing
22
Hello
上面的配置文件中,是用外部Bean注入的,我们也可以使用内部Bean注入,所谓内部Bean注入,是直接把Bean的定义写在property属性里,如下是更改后的配置文件
<!--
<bean id="sentence" class="com.pp.Sentence"/>
-->
<bean id="person" class="com.pp.Person">
<!-- 从这里可以看出的是属性名是setter方法里去掉set的部分,即setXXX中的XXX而与具体的属性无关 -->
<property name="name" value="pptest"></property>
<!-- 这里你完全可以把setaddr里的参数改成setaddr(String name),并不会报错,因为判断的依据是setXXX即XXX -->
<!-- 但如果你改成setS_addr这里就要错了,不信你可以试,如果改成setS_addr,则下面的name需要改成S_addr -->
<property name="addr" value="Beijing"></property>
<!-- 这里就是上面的一个例子,类的属性名为age,但这里的name却为S_Age -->
<!-- 同时这里也要说明的一个问题是类里面为int,但这里却是字符串类型,这个你不用担心,Spring在进行注入时会自动根据参数的类型进行类型 的转化 -->
<property name="S_Age" value="22"></property>
<!-- 引入在外部定义的bean,这里就是上面的一个bean的id
<property name="Sce" ref="sentence"></property>-->
<property name="Sce">
<!-- 内部的Bean不能被外部的Bean引用,因此在里面加入id属性,是没有什么用的,内部Bean只能供本类使用,这里就是Person类的一个对象 -->
<bean class="com.pp.Sentence"></bean>
</property>
</bean>
测试文件可以不加任何改动,但最终的运行结果是一样的
分享到:
相关推荐
SPRING DI注入例子 jar包没有包含
java Spring DI依赖注入.rar
Spring依赖注入(DI)的例子,包括接口注入、构造注入、set注入的简单类型和复杂类型注入的例子。
Spring依赖注入DI.zip
Spring Ioc DI 时序图分享给大家,希望对大家看源码有所帮助,不足之处欢迎批评指正,可以在下方留言
JavaEE spring 依赖注入DI入门案例
我们学习了spring框架spring框架里面有3个优势第一个是轻量级的IOC也叫控制反转后来改名为DI也叫依赖注入,依赖注入里面有3中注入方法分别是set注入,构造器注入,注解注入,我传的是set注入的视频
IOC与DI的理解及使用 控制反转IOC(Inversion of Control)是一种设计思想,DI(依赖注入)是实现IOC的一种方法 。... 在Spring中实现控制反转的是IOC容器 ,其 实现方法是依赖注入 (Dependency Injection,DI)
IOC DI 一个spring4.2.0 spring setter 和构造 注入 的小例子
spring 控制反转和依赖注入进行基础知识的生命周期、延迟初始化、装配方式等进行案例总结使用。从而对spring基础知识更加理解。
基于XML的依赖注入测试程序,配合博客资源学习。是基于XML的依赖注入方法的测试程序!
详细讲解了springioc的各种注入方式以及对应的java方式。讲解了springioc和DI的区别,以及注入特殊复杂的属性
今天有空,写了基于C#使用Spring.Net的演示实例,希望能给有需要的人带来帮助,其中演示了配置下的IOC、AOP、属性注入、构造函数注入、通知过滤器、以及不使用配置直接代码硬编的AOP动态代码过程,另外还增加了...
该项目使用spring作为依赖项注入,并在测试中注入步骤,并在步骤中注入页面。 这里的哲学是:“保持简单,愚蠢”。 要求 Java 8,Junit 5,Maven 从命令行运行测试 mvn清洁测试。 或mvn clean test -Dtags = smoke ...
- 构造器注入 - 属性(setter)注入 容器 容器是管理 组件的生命周期,注入组件(声明)所需的资源 例如: 容器 : 国家 义务教育、纳税、社保、医疗、养老 组件 : 公民 - apache tomcat 是 JSP/Servlet 容器,...
spring dom4j 解析 依赖DI注入 ioc 反转 反射原理 反射技术
技术分享:详解Spring基于Annotation的依赖注入实现
3. 如果一切正常,你会看到使用Java集合、XML API,以及反射技术模拟Spring的get注入和自定义的IoC容器实现的例子--get注入了Hello类和一个MyFrame类,并且实例化之后可以运行! 4. 看一下testDemoSpringDI()方法,...
【课堂笔记】一步一步手绘Spring+DI运行时序图,spring注入流程,bean创建过程
spring.jar是包含有完整发布的单个jar包,spring.jar中包含除了 spring-mock.jar里所包含的内容外其它所有jar包的内容,因为只有在开发环境下才会用到spring-mock.jar来进行辅助测试,正式应用系统中是用不得这些类...