菜鸟学习spring IOC有感



一、spring IOC思想引入

事实上对于刚開始学习的人来说,在学习IOC的时候确实有点困难,主要是掌握其思想方面存在一丢丢的障碍,可是假设可以跨过这个障碍,则可以高速掌握当中的思想了。单从字面上来讲,事实上IOC(反向控制)指的就是控制方向发生了变化。我们常常会遇到这句话:“实现必须依赖抽象,而不是抽象依赖实现。”尽管这句话表达了反向控制的概念,可是对于刚開始学习的人来讲,确实不是非常好理解。接下来我们就通过一些实例去理解这些内容的含义。

首先我们创建两个类,一个用于连接数据库,一个通过连接数据库实现获取数据库数据。

1)通常我们都是先编写一个连接数据的类MysqlDatabaseConnection.java,当中getData()是为了获取数据库中的数据。

Public class MysqlDatabaseConnection{
	……
	public list getData(){
		……
	}
}

 2)在处理业务时,我们须要在连接数据库之后可以获得数据,因此在处理业务逻辑时建立一个DoBussiness的类,代码这样实现:

Public class  DoBussiness{
	Private MysqlDatabaseConnection db=new MysqlDatabaseConnection();
	……
	Public void getData(){
		……
		List list=db.getData();
	}
}

 这样一来,我们功能基本实现了。可是,我们细致分析会发现一个问题,但我的想换一个数据库连接时,发现必须重写数据库连接代码,比方说我们想用Oracle连接数据库时,得写一个连接Oracle的类。

Public class OracleDatabaseConnection{
	……
	public list getData(){
		……
	}
}

 这样,我们就会发现,事实上我们的业务逻辑类DoBusiness是依赖于数据库的连接类,假设今天要用MySQL,明天换Oracle,后天来个DB2What can we fucking do!假设我们公司刚開始是个小公司,随着公司的不断成长,业务不断丰富多变,那么要频繁改动我们的业务逻辑类就感觉太CD了。好吧,好像有点扯到了软件重构相关东西。

 

到这里,我们发现,这不是一个非常好地设计,由于每次业务的变化都要涉及大量程序改动。怎样设计一个模式,可以解决这样的问题呢。解决问题我们须要明确:我们是须要实现业务逻辑可以重用的设计模式。我们试着这样去考虑

1.编写一个通用的接口类DatabaseConnection

Public interface DatabaseConnection{
	……
	Public List getData();
}

 
 


2.依据业务的不同编写详细负责数据库连接的类,比方说MysqlDatabaseConnection

Public class MysqlDatabaseConnection implements DatabaseConnection{
	……
	public LIst getData(){
		……
	}
}

 
3.编写业务逻辑类DoBusiness,该类仅仅针对接口实现编码,而不针对详细的实现类(这就是上面说的实现必须依赖与抽象)。

Public class  DoBussiness{
	Private DatabaseConnection db=new DatabaseConnection();
	Public void setDatabaseConnection(DatabaseConnection db){
	this.db=db;
	}
	……
	Public void getData(){
		……
		List list=db.getData();
	}
}

 4.当我们要处理业务的时候,我们就能够依据我们想要的数据库连接来动态改变了。这个时候我们採取的措施是将数据库注入到业务逻辑类DoBusiness中(自己好好体会)。

Public class  CallBussiness{
	Private DoBussiness do=new DoBussiness();
	……
	Public void getData(){
		……
		//注入数据库,假设要改动了数据库,我们须要替换掉注入的数据库就能够了
		Do. setDatabaseConnection(new MysqlDatabaseConnection());
		List list=db.getData();
		……
	}
}

 

总结一下:我们看看控制怎样反转的。

 

 

 起初,DoBusiness类是被各种数据库连接牵着鼻子走的,也就是被详细的数据库类控制。但是,当我们实现了数据库注入后,我们发现,情况发生了变化。

 
 

 

 

 因为注入的突出贡献,给入驻颁了个奖叫“依赖注入突出贡献奖”。由此IOC又叫依赖注入DI

二、依赖注入的三种实现方式。

1.接口注入,前面讲的就是接口注入。

2.set注入,在接受注入的类中定义一个Set方法,并在參数中定义须要注入的元素。

3.构造注入,在接受注入的类中定义一个构造方法,并在參数中定义须要注入的元素。

依照那种注入方式,各有说法,这里不一一讲述。

三、bean的管理。

Spring的核心容器实现了IOC,其目的是提供一种无侵入式的框架,为了实现之,在Spring中存在两个基本且很重要的包,org.springframework.beansorg.springframework,context。其代码中大量 存在Java反射机制。这两个包中,最重要的类是BeanFactoryApplicationContextApplicationContext建立在BeanFactory基础上,并添加了一些比方国际化,事件传递等功能。

1.bean的基础知识

1bean的标志是由Id或者name来接界定的

2beanclass属性表明了bean的来源。

3bean的部署模式,有共享型和非共享型。

4bean重要的属性property

5bean的依赖depends-on能够在初始化使用bean之前,强制运行一个过多个bean的初始化。

6bean的生命周期能够从bean的定义、bean的初始化,和bean的销毁4个阶段。

 

2.bean的生命周期

1bean的定义一般通过配置文档的方式来定义Bean

2bean的初始化有两种方式:init-method属性完毕,实现

org.springframework.beans.factory.InitializationBean接口。假设实现了该接口,那么全部必要的属性被BeanFactory设置后,会自己主动运行他的afterPropertiesSet()方法。

3bean的使用有三种方式:第一种是BeanWrapper,另外一种是BeanFactory,第三种是ApplicationContext

4bean的销毁有两种方式:第一种通过destroy-method属性完毕,另外一种是实现org.springframework.beans.factory.DisposableBean接口,那么会自己主动运行destroy()方法。

 

3.bean的自己主动装配

通过beanautowire来指定bean自己主动装配,共同拥有5种模式自己主动装配。

1byName模式:通过bean属性名字进行自己主动装配,在Spring的配置文档XML中,查找一个与将要装配的属性相同名字的Bean

2bytype模式:假设XML中正好有一个与属性类型一样的bean,就自己主动装配这个属性。

3constructor模式:依据构造函数的參数进行自己主动装配。

4autodetect模式:通过bean检查类的内部来选择constructorbytpe。先constructorbytype

5no模式:不使用自己主动装配。

尽管有了自己主动装配能够降低开发者的输入工作,可是却非常难看出bean的每一个属性是否都设定完毕,所以不建议自己主动装配。若确实使用了自己主动装配,怎样检查bean的每一个属性是否设定完毕呢?请看Bean的依赖检查。

 

4.Bean的依赖检查

依赖检查有四种模式:simple,object,all,none。使用beandependency-check属性来指定。普通情况下,依赖检查和自己主动装配是结合使用的。

1simple模式:仅仅对基本类型,字符串和集合进行依赖检查。

2object模式:对依赖的对象进行依赖检查

3all模式:对所有属性进行依赖检查。

4none模式:不进行依赖检查。

<假设理解有误,还请指教>


posted @ 2014-09-21 18:03  mengfanrong  阅读(598)  评论(0编辑  收藏  举报