Spring 作為一個輕量級的 Java 開發框架,將面向介面的程式設計思想貫穿整個 Java 系統應用,因此在 Java 面試中常被提。Spring 框架知識是網際網路公司面試必考知識點。今天通過這些題來大致的瞭解一下Spring框架
什麼是spring
Spring 是個Java企業級應用的開源開發框架。Spring主要用來開發Java應用,但是有些擴充套件是針對構建J2EE平臺的web應用。Spring 框架目標是簡化Java企業級應用開發,它使得開發者只需要關心業務需求。
spring優點
spring有哪些模組組成
本人準備了20年多家面試題與核心知識總結,下圖是部分截圖,需要的同學點選進入自行領取,暗號CSDN
IOC: 控制反轉,把建立物件的控制權利由程式碼轉移到spring的組態檔中。
最直觀的表達就是,IOC讓物件的建立不用去new了,可以由spring自動生產,使用java的反射機制,根據組態檔在執行時動態的去建立物件以及管理物件,並呼叫物件的方法的。
DI:依賴注入,在程式執行期間,由外部容器動態地將依賴物件注入到元件中。簡單定義就是當一個物件需要另一個物件時,可以把另一個物件注入到物件中去。
優點就是把應用的程式碼量降到最低,達到鬆散耦合度。
注入的方式:
構造注入
Set注入
介面注入
Spring提供以下幾種集合的設定元素:
型別用於注入一列值,允許有相同的值。
型別用於注入一組值,不允許有相同的值。
型別用於注入一組鍵值對,鍵和值都只能為String型別。
aop面向切面程式設計,關鍵在於代理模式,Spring AOP使用的動態代理,所謂的動態代理就是說AOP框架不會去修改位元組碼,而是每次執行時在記憶體中臨時為方法生成一個AOP物件,這個AOP物件包含了目標物件的全部方法,並且在特定的切點做了增強處理,並回撥原物件的方法。動態代理可以減少系統中的重複程式碼,降低了模組間的耦合度,同時提高了系統的可維護性。可用於許可權認證、紀錄檔、事務處理。
Spring AOP中的動態代理主要有兩種方式,JDK動態代理和CGLIB動態代理:
Proxy.newProxyInstance(ClassLoader,Interfaces,InvocationHandler);
Enhancer是一個非常重要的類,它允許為非介面型別建立一個JAVA代理,Enhancer動態的建立給定類的子類並且攔截代理類的所有的方法,和JDK動態代理不一樣的是不管是介面還是類它都能正常工作
sping的動態代理通過代理類為目標物件增加額外功能。
代理本質 = 目標物件+額外功能+代理物件的介面
開發步驟:
建立原始物件
提供額外功能(實現下面的介面)
MethodBeforeAdvice 額外功能需要執行在原始方法之前執行.
AfterReturningAdvice 額外功能需要執行在原始方法之後執行
MethodInterceptor 額外功能需要執行在原始方法之前 後執行
ThrowsAdvice 額外功能執行在原始方法丟擲異常的執行
<aop:pointcut expression="execution(* *(..))"/>
<aop:advisor pointcut-ref="pc" advice-ref="代理功能的bean"/>
需要下圖資料的點這裡,暗號CSDN
Spring事務的本質其實就是資料庫對事務的支援,沒有資料庫的事務支援,spring是無法提供事務功能的。
(1)Spring事務的種類:
spring支援程式設計式事務管理和宣告式事務管理兩種方式:
①程式設計式事務管理使用TransactionTemplate。
②宣告式事務管理建立在AOP之上的。其本質是通過AOP功能,對方法前後進行攔截,將事務處理的功能編織到攔截的方法中,也就是在目標方法開始之前加入一個事務,在執行完目標方法之後根據執行情況提交或者回滾事務。
宣告式事務最大的優點就是不需要在業務邏輯程式碼中摻雜事務管理的程式碼,只需在組態檔中做相關的事務規則宣告或通過@Transactional註解的方式,便可以將事務規則應用到業務邏輯中。
宣告式事務管理要優於程式設計式事務管理,這正是spring倡導的非侵入式的開發方式,使業務程式碼不受汙染,只要加上註解就可以獲得完全的事務支援。唯一不足地方是,最細粒度只能作用到方法級別,無法做到像程式設計式事務那樣可以作用到程式碼塊級別。
(2)spring的事務傳播行為:
spring事務的傳播行為說的是,當多個事務同時存在的時候,spring如何處理這些事務的行為。
① PROPAGATION_REQUIRED:如果當前沒有事務,就建立一個新事務,如果當前存在事務,就加入該事務,該設定是最常用的設定。
② PROPAGATION_SUPPORTS:支援當前事務,如果當前存在事務,就加入該事務,如果當前不存在事務,就以非事務執行。‘
③ PROPAGATION_MANDATORY:支援當前事務,如果當前存在事務,就加入該事務,如果當前不存在事務,就丟擲異常。
④ PROPAGATION_REQUIRES_NEW:建立新事務,無論當前存不存在事務,都建立新事務。
⑤ PROPAGATION_NOT_SUPPORTED:以非事務方式執行操作,如果當前存在事務,就把當前事務掛起。
⑥ PROPAGATION_NEVER:以非事務方式執行,如果當前存在事務,則丟擲異常。
⑦ PROPAGATION_NESTED:如果當前存在事務,則在巢狀事務內執行。如果當前沒有事務,則按REQUIRED屬性執行。
(3)Spring中的隔離級別:
① ISOLATION_DEFAULT:這是個 PlatfromTransactionManager 預設的隔離級別,使用資料庫預設的事務隔離級別。
② ISOLATION_READ_UNCOMMITTED:讀未提交,允許另外一個事務可以看到這個事務未提交的資料。
③ ISOLATION_READ_COMMITTED:讀已提交,保證一個事務修改的資料提交後才能被另一事務讀取,而且能看到該事務對已有記錄的更新。解決髒讀問題
④ ISOLATION_REPEATABLE_READ:可重複讀,保證一個事務修改的資料提交後才能被另一事務讀取,但是不能看到該事務對已有記錄的更新。行鎖
⑤ ISOLATION_SERIALIZABLE:一個事務在執行的過程中完全看不到其他事務對資料庫所做的更新。表鎖
(4)唯讀屬性(readOnly)
false應用在查詢操作時,提高查詢效率, true用於查詢,false用於增刪改,預設是false
(5)超時屬性(timeout) 秒 -1 由資料庫決定
如果當前事務操作的資料,被別的事務鎖住,那麼通過超時資料指定最多等待多少秒.
(6)異常屬性(±Exception)
預設Spring會對RuntimeException及其子類進行回滾操作
預設Spring會對Exception及其子類進行提交操作
rollback-for=」異常的許可權定名」 回滾操作
no-rollback-for=」java.lang.RuntimeException」 提交操作
簡單展示
將Spring設定到應用開發中有以下三種方式:
基於XML的設定
基於註解的設定(主流)
基於Java的設定
在spring中,物件無需自己查詢或建立與其關聯的其他物件,由容器負責把需要相互共同作業的物件參照賦予各個物件,使用autowire來設定自動裝載模式。
在Spring框架xml設定中共有5種自動裝配:
(1)no:預設的方式是不進行自動裝配的,通過手工設定ref屬性來進行裝配bean。
(2)byName:通過bean的名稱進行自動裝配,如果一個bean的 property 與另一bean 的name 相同,就進行自動裝配。
(3)byType:通過引數的資料型別進行自動裝配。
(4)constructor:利用建構函式進行裝配,並且建構函式的引數通過byType進行裝配。
(5)autodetect:自動探測,如果有構造方法,通過 construct的方式自動裝配,否則使用 byType的方式自動裝配。
基於註解的方式:
使用@Autowired註解來自動裝配指定的bean。在使用@Autowired註解之前需要在Spring組態檔進行設定,<context:annotation-config />。在啟動spring IoC時,容器自動裝載了一個AutowiredAnnotationBeanPostProcessor後置處理器,當容器掃描到@Autowied、@Resource或@Inject時,就會在IoC容器自動查詢需要的bean,並裝配給該物件的屬性。在使用@Autowired時,首先在容器中查詢對應型別的bean:
如果查詢結果剛好為一個,就將該bean裝配給@Autowired指定的資料;
如果查詢的結果不止一個,那麼@Autowired會根據名稱來查詢;
如果上述查詢的結果為空,那麼會丟擲異常。解決方法時,使用required=false。
@Autowired可用於:建構函式、成員變數、Setter方法
注:@Autowired和@Resource之間的區別
(1) @Autowired預設是按照型別裝配注入的,預設情況下它要求依賴物件必須存在(可以設定它required屬性為false)。
(2) @Resource預設是按照名稱來裝配注入的,只有當找不到與名稱匹配的bean才會按照型別來裝配注入。
在一般情況下,只有無狀態的Bean才可以在多執行緒環境下共用,在Spring中,絕大部分Bean都可以宣告為singleton作用域,因為Spring對一些Bean中非執行緒安全狀態採用ThreadLocal進行處理,解決執行緒安全問題。
ThreadLocal和執行緒同步機制都是為了解決多執行緒中相同變數的存取衝突問題。同步機制採用了「時間換空間」的方式,僅提供一份變數,不同的執行緒在存取前需要獲取鎖,沒獲得鎖的執行緒則需要排隊。而ThreadLocal採用了「空間換時間」的方式。
ThreadLocal會為每一個執行緒提供一個獨立的變數副本,從而隔離了多個執行緒對資料的存取衝突。因為每一個執行緒都擁有自己的變數副本,從而也就沒有必要對該變數進行同步了。ThreadLocal提供了執行緒安全的共用物件,在編寫多執行緒程式碼時,可以把不安全的變數封裝進ThreadLocal。
Spring容器中的bean可以分為5個範圍:
(1)singleton:預設,每個容器中只有一個bean的範例,單例的模式由BeanFactory自身來維護。
(2)prototype:為每一個bean請求提供一個範例。
(3)request:為每一個網路請求建立一個範例,在請求完成以後,bean會失效並被垃圾回收器回收。
(4)session:與request範圍類似,確保每個session中有一個bean的範例,在session過期後,bean會隨之失效。
(5)global-session:全域性作用域,global-session和Portlet應用相關。當你的應用部署在Portlet容器中工作時,它包含很多portlet。如果你想要宣告讓所有的portlet共用全域性的儲存變數的話,那麼這全域性變數需要儲存在global-session中。全域性作用域與Servlet中的session作用域效果相同。
註解裝配在預設情況下是不開啟的,為了使用註解裝配,我們必須在Spring組態檔中設定 < context:annotation-config/>元素。
BeanFactory:產生一個新的範例,可以實現單例模式
BeanWrapper:提供統一的get及set方法
ApplicationContext:提供框架的實現,包括BeanFactory的所有功能
不,Spring框架中的單例bean不是執行緒安全的。
在我們的開發中離不開Spring,所以瞭解spring,如何使用spring是重中之重。本人總結了Spring的知識大全,從基礎設定到高階使用原理都有講到,需要的同學可以點這裡領取,暗號CSDN。 下圖是部分資料截圖,希望能幫助到你們。