Spring架構本身有四大原則:
1)使用POJO進行輕量級和最小侵入式開發。
2)通過依賴注入和基于接口程式設計實作松耦合。
3)通過AOP和預設習慣進行聲明式程式設計。
4)使用AOP和模闆減少模式化代碼。
Spring所有功能的設計和實作都是基于此四大原則的。
我們經常說的控制翻轉和依賴注入在Spring環境下是等同的概念,控制翻轉是通過依賴注入實作的。所謂依賴注入指的是容器負責建立對象和維護對象間的依賴關系,而不是通過對象本身負責自己的建立和解決自己的依賴。
依賴注入的主要目的是為了解耦,展現了一種“組合”的理念。
Spring IoC容器(ApplicationContext)負責建立Bean,并通過容器将功能類Bean注入到你需要的Bean中。Spring提供xml,注解,java配置,groovy配置實作Bean的建立和注入。
聲明Bean的注解:
——@Component元件,沒有明确的角色
——@Service 在業務邏輯層(service層)使用
——@Repository 在資料通路層(dao層)使用
——@Controller 在展現層(MVC——>Spring MVC)使用
注入Bean的注解,一般情況下通用。
——@Autowired:Spring提供的注解。對類成員變量,方法及構造函數進行标注,完成自動裝配,來消除set,get方法。
——@Inject:JSR-330提供的注解
——@Resource:JSR-250提供的注解
@Autowired,@Inject,@Resource可注解在set方法或屬性上,我習慣注解在屬性上,優點是代碼更少,層次更加清晰。
接下來示範基于注解的Bean的初始化和依賴注入,Spring容器類選用AnnotationConfigApplicationContext。
示例項目結構如下圖:

(1)編寫功能類的Bean:
package com.wisely.highlight_spring4.chl.di;
import org.springframework.stereotype.Service;
@Service
public class FunctionService {
public String sayHello(String word) {
return "Hello " +word+ " !";
}
}
使用@Service注明目前Function類是Spring管理的一個Bean。
(2)使用功能類的Bean:
package com.wisely.highlight_spring4.chl.di;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UseFunctionService {
@Autowired
FunctionService functionService;
public String SayHello(String word) {
return functionService.sayHello(word);
}
}
使用@Autowired将FunctionService的實體Bean注入到UseFunctionService中,讓UseFunctionService具有FunctionService的功能。
(3)配置類。
package com.wisely.highlight_spring4.chl.di;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@ComponentScan("com.wisely.highlight_spring4.chl.di")
public class DiConfig {
}
@Configuration聲明目前類是一個配置類。
@使用ComponentScan會自動掃描所有使用聲明Bean的類,并注冊為Bean。
(4)運作
package com.wisely.highlight_spring4.chl.di;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class Main {
public static void main(String[] args) {
AnnotationConfigApplicationContext context =new AnnotationConfigApplicationContext(DiConfig.class);
UseFunctionService useFunctionService=context.getBean(UseFunctionService.class);
System.out.println(useFunctionService.SayHello("di"));
context.close();
}
}
運作結果如下: