第一天学习spring,讲的是spring中的IOC控制反转。顾名思义,就是将对象的创建权力反转给Spring框架,这样做的好处是降低代码的耦合性。
之前我们的做法是自己创建对象,调用方法,假如后面我们发现这个类不符合我们的要求了,我们需要重新写一个类,并且要修改源代码来调用这个新的类,耦合性很高,违反了设计原则的开闭原则。IOC就是spring帮我们创建对象,而创建哪个对象则是我们通过配置文件告诉spring的,这样如果重新写一个类,只需要修改配置文件,不需要修改源代码了。所以ioc降低了代码的耦合性,便于后期维护。
要实现IOC需要依赖配置文件与创建对象的工厂类。栗子中的spring使用的是4.2.4.RELEASE版本。
首先看一下创建对象的工厂类,它是通过反射的方式创建对象的。
//推荐使用的方法,使用相对路径的配置文件
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
还有一个是获取绝对路径的配置文件创建的方法,还有一个过时的方法,使用的是:
BeanFactory factory = new XmlBeanFactory(new ClassPathResource("applicationContext.xml"));过时方法,不推荐使用。
再来看一下配置文件:
id="UserDao" class="com.itheima.dao.impl.UserDaoImpl">
id要保证唯一,class里面是要实例化的类的全名,代码会在最后贴出来。
上图展示了3种创建的方法,基本都是使用默认的方法。
bean标签中还有一个参数。scope,作用域。最常用的是单例,不需要配置。
singleton:单例(默认值)
prototype:多例,在Spring框架整合Struts2框架的时候,Action类也需要交给Spring做管理,配置把Action类配置成多例!!
request:应用在web应用中,将创建的对象存入到request域中。
session:应用在web应用中,将创建的对象存入到session域中
globalsession:应用在porlet环境下使用。将创建的对象存入到全局的session中。
pom.xml
xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
4.0.0
com.itheima
springtest1
1.0-SNAPSHOT
jar
springtest1
http://maven.apache.org
UTF-8
org.springframework
spring-context
4.2.4.RELEASE
log4j
log4j
1.2.12
junit
junit
4.10
test
org.apache.maven.plugins
maven-compiler-plugin
3.1
1.7
1.7
utf-8
org.apache.maven.plugins
maven-surefire-plugin
2.7.1
-Dfile.encoding=UTF-8
xml version="1.0" encoding="UTF-8"?>xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 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/context http://www.springframework.org/schema/context/spring-context.xsd" > id="UserDao" class="com.itheima.dao.impl.UserDaoImpl"> id="UserDao1" class="com.itheima.factory.FactoryDemo" factory-method="getInstance"> id="factory" class="com.itheima.factory.FactoryDemo" > id="UserDao2" factory-bean="factory" factory-method="newInstance">
FactoryDemo:
public class FactoryDemo { public static Object getInstance(){ return new UserDaoImpl(); } public Object newInstance() { return new UserDaoImpl(); } }
UserDao 与 实现类
public interface UserDao { void help(); }
public class UserDaoImpl implements UserDao { @Override public void help() { System.out.println("帮帮忙撒....."); } }
测试类:
public class IOCTest1 { /** * 默认方法创建对象 */ @Test public void test1(){ ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml"); UserDao userDao = (UserDao)ac.getBean("UserDao"); userDao.help(); } /** * 静态方法创建对象 */ @Test public void test2(){ ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml"); UserDao userDao = (UserDao)ac.getBean("UserDao1"); userDao.help(); } /** * 实例化方法创建对象 */ @Test public void test3(){ ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml"); UserDao userDao = (UserDao)ac.getBean("UserDao2"); userDao.help(); } }
log4j.properties:
log4j.rootLogger=INFO,Console #debug,info,warning,error4jibie ConsoleAppender: output Console layout: output style log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.layout=org.apache.log4j.PatternLayout log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n ### %d==> time %t==> thread %-5p ==>%p:shuchujibie 5:5gezifu -:zuoduiqi %c:shuchudeleidequanming %m:shuchufujiaxinxi %n:huanhang log4j.logger.org.apache=INFO