Springd的Ioc和AOP扩展

多种方式实现依赖注入:

这里唯一需要说明的是如果要使用P命名空间实现属性注入,需要添加命名空间的声明:

如我的xml里红色字体:

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:p="http://www.springframework.org/schema/p" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/bean http://www.springframework.org/schema/beans/spring-beans.xsd">

<!-- 设置注入(通过访问器注入) 1.使用灵活2.时效性不足 -->

<bean id="a" class="cn.cnti.ioc.A">

<property name="a1" value="a1 hello"></property>

<property name="a2">

<!-- 赋值为特殊字符时需要用 -->

<value><![CDATA[<><><><><><>]]></value>

</property>

<property name="a3" value="60"></property>

</bean>

<bean id="a1" class="cn.cnti.ioc.A">

<property name="a1">

<value>a1 hello</value>

</property>

<property name="a2">

<value>a2 hello</value>

</property>

<property name="a3">

<value>80</value>

</property>

</bean>

<!-- 通过构造注入 1.时效性好2.灵活性不足 -->

<bean id="a2" class="cn.cnti.ioc.A">

<constructor-arg index="0" value="a1 hello"></constructor-arg>

<constructor-arg index="1" value="a2 hello"></constructor-arg>

<constructor-arg index="2" value="98"></constructor-arg>

</bean>

<bean id="a3" class="cn.cnti.ioc.A">

<constructor-arg name="a1" value="a1 hello"></constructor-arg>

<constructor-arg name="a2" value="a2 hello"></constructor-arg>

<constructor-arg name="a3" value="99"></constructor-arg>

</bean>

<bean id="a4" class="cn.cnti.ioc.A">

<constructor-arg type="java.lang.String" value="a1 hello"></constructor-arg>

<constructor-arg type="java.lang.String" value="a2 hello"></constructor-arg>

<constructor-arg type="java.lang.Integer" value="100"></constructor-arg>

</bean>

<!-- 使用p命名空间的注入,首先需要添加p命名空间的声明 -->

<bean id="a5" class="cn.cnti.ioc.A" p:a1="a1 hello" p:a2="a2 hello"

p:a3="101" />

<!-- 注入集合类型的属性 -->

<bean id="a6" class="cn.cnti.ioc.A">

<!-- list集合 -->

<property name="list">

<list>

<value>hello1</value>

<value>hello2</value>

<value>hello3</value>

</list>

</property>

<property name="listB">

<list>

<ref bean="b" />

<ref bean="b" />

<ref bean="b" />

</list>

</property>

<!-- set集合 -->

<property name="set">

<set>

<value>he</value>

<value>hel</value>

<value>hello</value>

</set>

</property>

<property name="setB">

<set>

<ref bean="b" />

</set>

</property>

<!-- map集合 -->

<property name="map">

<map>

<entry>

<key>

<value>one</value>

</key>

<value>1</value>

</entry>

<entry>

<key>

<value>two</value>

</key>

<value>2</value>

</entry>

<entry>

<key>

<value>three</value>

</key>

<value>3</value>

</entry>

</map>

</property>

<property name="mapO">

<map>

<entry>

<key>

<value>one</value>

</key>

<ref bean="b" />

</entry>

<entry>

<key>

<value>two</value>

</key>

<ref bean="b" />

</entry>

<entry>

<key>

<value>three</value>

</key>

<ref bean="b" />

</entry>

</map>

</property>

</bean>

<bean id="b" class="cn.cnti.ioc.B" p:b="hello b"></bean>

<!-- map集合(集合里没有对象)的另一种简单用法 -->

<bean id="a7" class="cn.cnti.ioc.A">

<property name="map">

<props>

<prop key="one">he</prop>

<prop key="two">hel</prop>

<prop key="three">hello</prop>

</props>

</property>

</bean>

<!-- 使用内部bean -->

<bean id="a8" class="cn.cnti.ioc.A">

<property name="b">

<bean class="cn.cnti.ioc.B">

<property name="b" value="i am b"></property>

</bean>

</property>

</bean>

</beans>

我的实体类A:

package cn.cnti.ioc;

import java.util.List;

import java.util.Map;

import java.util.Set;

public class A {

private String a1;

private String a2;

private Integer a3;

// 测试内部bean

private B b;

// 测试各种集合

List<String> list;

List<B> listB;

Set<String> set;

Set<B> setB;

Map<String, String> map;

Map<String, Object> mapO;

public A() {

}

public A(String a1, String a2, Integer a3) {

this.a1 = a1;

this.a2 = a2;

this.a3 = a3;

}

public String getA1() {

return a1;

}

public void setA1(String a1) {

this.a1 = a1;

}

public String getA2() {

return a2;

}

public void setA2(String a2) {

this.a2 = a2;

}

public Integer getA3() {

return a3;

}

public void setA3(Integer a3) {

this.a3 = a3;

}

public List<String> getList() {

return list;

}

public void setList(List<String> list) {

this.list = list;

}

public List<B> getListB() {

return listB;

}

public void setListB(List<B> listB) {

this.listB = listB;

}

public Set<String> getSet() {

return set;

}

public void setSet(Set<String> set) {

this.set = set;

}

public Set<B> getSetB() {

return setB;

}

public void setSetB(Set<B> setB) {

this.setB = setB;

}

public Map<String, String> getMap() {

return map;

}

public void setMap(Map<String, String> map) {

this.map = map;

}

public Map<String, Object> getMapO() {

return mapO;

}

public void setMapO(Map<String, Object> mapO) {

this.mapO = mapO;

}

public B getB() {

return b;

}

public void setB(B b) {

this.b = b;

}

@Override

public String toString() {

return "A [a1=" + a1 + ", a2=" + a2 + ", a3=" + a3 + ", b=" + b

+ ", list=" + list + ", listB=" + listB + ", set=" + set

+ ", setB=" + setB + ", map=" + map + ", mapO=" + mapO + "]";

}

}

我的实体类B:

package cn.cnti.ioc;

public class B {

private String b;

public String getB() {

return b;

}

public void setB(String b) {

this.b = b;

}

@Override

public String toString() {

return "B [b=" + b + "]";

}

}

我的实体类C:

package cn.cnti.ioc;

public class C {

private String C;

public String getC() {

return C;

}

public void setC(String c) {

C = c;

}

@Override

public String toString() {

return "C [C=" + C + "]";

}

}

时间: 2024-10-17 17:52:10

Springd的Ioc和AOP扩展的相关文章

IOC和AOP扩展

L120201X1 构造注入,在L120108X1的项目上做出以下改变 1.改变UserServiceImpl.java成以下内容 package service.impl; import dao.UserDao; import entity.User; import service.UserService; //用户业务类,实现对User功能的业务管理 public class UserServiceImpl implements UserService { //声明接口类型的引用,和具体实现

Spring IOC及AOP学习总结

一.Spring IOC体系学习总结: Spring中有两个容器体系,一类是BeanFactory.另一类是ApplicationContext.BeanFactory提供了基础的容器功能.ApplicationContext则是基于BeanFactory建立的一套更加丰富的容器体系,基于ApplicationContext构建了Spring AOP体系(基于AOP体系又构建了声明式事务模型),I18n的支持,基于观察者模式的事件模型,多渠道的Bean资源的载入(比如从文件系统,从interne

Spring入门导读——IoC和AOP

和MyBatis系列不同的是,在正式开始Spring入门时,我们先来了解两个关于Spring核心的概念,IoC(Inverse of Control)控制反转和AOP()面向切面编程. 1.IoC(Inversion of Control)控制反转 什么是控制反转呢?可以这么通俗的来解释,我们通常写代码当一个类会关联另一个类是会直接在这个类里new,例如: 1 package day_30_spring; 2 3 /** 4 * @author 余林丰 5 * 6 * 2016年10月30日 7

Java深度历险(四) 深入浅出-----IOC AND AOP

IOC就是Inversion of Control,控制反转.在Java开发中,IoC意味着将你设计好的类交给系统(容器)来控制实现,而不是在你的类内部控制.这称为控制反转. 本人理解:就是把原本你自己制造,使用的对象,现在交由别人制造,而通过构造函数(容器来管理),setter方法或方法(这里指使用这个对象的方法)参数的方式传给自己,由自己使用. 实例说明形象理解IOC 要设计一个Girl和一个Boy类,其中Girl有recognize方法,即Girl想要recognize一个Boy.那么,我

spring的IOC和AOP

spring的核心就是IOC和AOP. IOC(控制反转)和DI(依赖注入)是同一个概念.具体的讲:当某个角色需要另外一个角色协助的时候,在传统的程序设计过程中,通常由调用者来创建被调用者的实例.但在spring中 创建被调用者的工作不再由调用者来完成,因此称为控制反转.创建被调用者的工作由spring来完成,然后注入调用者因此也称为依赖注入.所谓依赖,从程序的角度看,就是比如A要调用B的方法,那么A就依赖于B,反正A要用到B,则A依赖于B.举个生活中的例子:通常情况下,假如你有一天在家里口渴了

maven-tomcat7;IOC;AOP;数据库远程连接

[说明]真的是好烦下载插件啊,maven-tomcat7 插件试了好多次都不行,下载不成:部署不成:好不容易从github中得到的springmvc项目也是运行不起来,中间又是查了许多东西,绕着绕着都不知到到那里了,啊啊啊 [说明]明天还有我们郑州这边的分享,按说该到我了,还得好好准备,, 一:今日完成 1)spring建了一个简单的javaweb项目,大概实验了IOC和AOP的功能 不过到后面springmvc运行的时候,因为修改了server.xml文件,出现了好多问题,tomcat启动不了

spring的IOC和AOP详细讲解

1.解释spring的ioc? 几种注入依赖的方式?spring的优点? IOC你就认为他是一个生产和管理bean的容器就行了,原来需要在调用类中new的东西,现在都是有这个IOC容器进行产生,同时,要是产生的是单例的bean,他还可以给管理bean的生命周期! spring的IOC有三种注入方式 : 第一是根据属性注入 也叫set方法注入: 第二种是根据构造方法进行注入: 第三种是根据注解进行注入,这种方式我认为比较好,方便,要是bean多的话,使用前两种方式会使得配置文件过于臃肿. Spri

Spring 的IOC 和Aop

Spring 的IOC 和Aop 在ApplicationContext.xml中,bean的scope属性默认是singleton,即默认是单例 Spring容器创建的时候,会将所有的配置的bean对象创建,默认bean都是单例的, 代码通过getBean()方法从容器获取指定的bean实例,容器首先会调用Bean类的无参构造器,创建实例对象 bean的作用域 scope=“prototype” 原型模型(N个对象),真正使用时才会创建,没获取一次,都会创建不同的对象 scopr="singl

spring - ioc和aop

1.程序中为什么会用到spring的ioc和aop 2.什么是IOC,AOP,以及使用它们的好处,即详细回答了第一个问题 3.原理 关于1: a:我们平常使用对象的时候,一般都是直接使用关键字类new一个对象,那这样有什么坏处呢?其实很显然的,使用new那么就表示当前模块已经不知不觉的和 new的对象耦合了,而我们通常都是更高层次的抽象模块调用底层的实现模块,这样也就产生了模块依赖于具体的实现,这样与我们JAVA中提倡的面向接口面向抽象编程是相冲突的,而且这样做也带来系统的模块架构问题.很简单的