Spring是目前主流的框架,使用Spring的目的主要是簡化開發。其實,大多數框架的目的都是爲了讓我們這些碼農搬起磚來更高效率,我們首先應明確學習框架的目的,而不應該爲了學習框架而去學框架。那麼,Spring是怎麼簡化開發的呢?先來看《Spring實戰》中的描述:
爲了降低Java開發的複雜性,Spring採取了以下4種關鍵策略:
基於POJO的輕量級和最小侵入性編程;
通過依賴注入和麪向接口實現鬆耦合;
基於切面和慣例進行聲明式編程;
通過切面和模板減少樣板式代碼。
總的來說,Spring中最重要的內容就是DI(依賴注入)和AOP(面向切面)。下面,我們先聊聊Ioc。
小明是一個苦逼的碼農,小紅是萬惡的產品經理。小紅給小明說明需求,小明就開始搬磚,上代碼:
//程序員接口
public interface Coder {
void coding();
}
//產品經理接口
public interface ProductManage {
void work();
}
//負責A部分的程序員
public class CoderA implements Coder {
private String name;
public CoderA(String name){
this.name=name;
}
@Override
public void coding() {
System.out.println("苦逼的碼農"+name+"正在搬磚...");
}
}
//產品經理A
public class ProductManageA implements ProductManage {
public ProductManageA(){
Coder xiaoming=new CoderA();
}
@Override
public void work() {
System.out.println("萬惡的PM跟碼農談需求");
xiaoming.coding();
}
}
//測試方法
@Test
public final void test() {
ProductManage xiaohong=new ProductManageA();
xiaohong.work();
}
測試結果:
萬惡的PM跟碼農談需求
苦逼的碼農xiaoming正在搬磚…
這裏,我們不難發現,產品經理與程序員耦合度太高了,小紅難道只能讓小明打代碼嗎?顯然,應該改進一下:
public class ProductManageA implements ProductManage {
private Coder coder;
public ProductManageA(Coder coder){
this.coder=coder;
}
@Override
public void work() {
System.out.println("萬惡的PM跟碼農談需求");
coder.coding();
}
}
測試方法:
@Test
public final void test() {
Coder xiaoming=new CoderA("xiaoming");
ProductManage xiaohong=new ProductManageA(xiaoming);
xiaohong.work();
}
`
顯然結果是一樣的,但這樣的好處就是耦合度降低了,小紅不僅可以安排小明打代碼,還可以安排小剛,小李啥的。這是一種代理模式,我們每次都要先new一個程序員,再由把程序員注入產品經理,完成這個工作。顯然比較繁瑣,而Spring是爲了簡化開發的,所以我們祭出Spring。在Spring中,就可以使用DI(依賴注入)來完成這個過程,相當於把小明注入,達到控制反轉的效果。
首先,我們首先在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:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="xiaohong" class="program.ProductManageA">
<constructor-arg ref="xiaoming" />
</bean>
<bean id="xiaoming" class="program.CoderA">
<constructor-arg value="xiaoming" />
</bean>
</beans>
然後,測試此次輸出
@Test
public final void test() {
FileSystemXmlApplicationContext context=
new FileSystemXmlApplicationContext("磁盤中位置/ProductManageA.xml");
ProductManageA pmA=context.getBean(ProductManageA.class);
pmA.work();
context.close();
}
“`
萬惡的PM跟碼農談需求
苦逼的碼農xiaoming正在搬磚…
完美輸出。我們可以發現,Spring幫助我們構造了程序員,簡化了編程。