日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

osgi框架和spring区别_BATJ面试必会之 Spring 篇(二)

發(fā)布時(shí)間:2024/1/23 javascript 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 osgi框架和spring区别_BATJ面试必会之 Spring 篇(二) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

原文鏈接: https://howtodoinjava.com/interview-questions/top-spring-interview-questions-with-answers/ 翻譯: ImportNew.com - 一直在路上

譯文鏈接: http://www.importnew.com/15851.html

整理:微信公眾號:程序員喬戈里

問題清單:

  • 什么是Spring框架?Spring框架有哪些主要模塊?

  • 使用Spring框架有什么好處?

  • 什么是控制反轉(zhuǎn)(IOC)?什么是依賴注入?

  • 請解釋下Spring中的IOC?

  • BeanFactory和ApplicationContext有什么區(qū)別?

  • 將Spring配置到你的應(yīng)用中共有幾種方法?

  • 什么基于XML的配置?

  • 什么基Java的配置?

  • 怎樣用注解的方式配置Spring?

  • 描述Spring Bean的生命周期?

  • 描述Spring中各種Bean的范圍?

  • 什么是Spring的嵌入beans?

  • Spring框架中的單例bean是否是線程安全的?

  • 請舉例說明如何用Spring注入一個(gè)Java的集合類?

  • 請舉例說明如何在Spring的Bean中注入一個(gè)java.util.Properties?

  • 請解釋Spring的Bean的自動(dòng)生成原理?

  • 請辨析自動(dòng)生成Bean之間模塊的區(qū)別?

  • 如何開啟基于基于注解的自動(dòng)寫入?

  • 請舉例說明@Required注解?

  • 請舉例說明@Autowired注解?

  • 請舉例說明@Qualifier注解?

  • 請說明構(gòu)造器注入和setter方法注入之間的區(qū)別?

  • Spring框架中不同類型event有什么區(qū)別?

  • FileSystemResource和ClassPathResource有何區(qū)別?

  • 請列舉Spring框架中用了哪些設(shè)計(jì)模式?

1、什么是Spring框架?Spring框架有哪些主要模塊?

Spring框架是一個(gè)為Java應(yīng)用程序的開發(fā)提供了綜合、廣泛的基礎(chǔ)性支持的Java平臺。Spring幫助開發(fā)者解決了開發(fā)中基礎(chǔ)性的問題,使得開發(fā)人員可以專注于應(yīng)用程序的開發(fā)。Spring框架本身亦是按照設(shè)計(jì)模式精心打造,這使得我們可以在開發(fā)環(huán)境中安心的集成Spring框架,不必?fù)?dān)心Spring是如何在后臺進(jìn)行工作的。

Spring框架至今已集成了20多個(gè)模塊。這些模塊主要被分如下圖所示的核心容器、數(shù)據(jù)訪問/集成,、Web、AOP(面向切面編程)、工具、消息和測試模塊。

2、使用Spring框架能帶來哪些好處?

下面列舉了一些使用Spring框架帶來的主要好處:

  • Dependency Injection(DI) 方法使得構(gòu)造器和JavaBean properties文件中的依賴關(guān)系一目了然。

  • 與EJB容器相比較,IoC容器更加趨向于輕量級。這樣一來IoC容器在有限的內(nèi)存和CPU資源的情況下進(jìn)行應(yīng)用程序的開發(fā)和發(fā)布就變得十分有利。

  • Spring并沒有閉門造車,Spring利用了已有的技術(shù)比如ORM框架、logging框架、J2EE、Quartz和JDK Timer,以及其他視圖技術(shù)。

  • Spring框架是按照模塊的形式來組織的。由包和類的編號就可以看出其所屬的模塊,開發(fā)者僅僅需要選用他們需要的模塊即可。

  • 要測試一項(xiàng)用Spring開發(fā)的應(yīng)用程序十分簡單,因?yàn)闇y試相關(guān)的環(huán)境代碼都已經(jīng)囊括在框架中了。更加簡單的是,利用JavaBean形式的POJO類,可以很方便的利用依賴注入來寫入測試數(shù)據(jù)。

  • Spring的Web框架亦是一個(gè)精心設(shè)計(jì)的Web MVC框架,為開發(fā)者們在web框架的選擇上提供了一個(gè)除了主流框架比如Struts、過度設(shè)計(jì)的、不流行web框架的以外的有力選項(xiàng)。

  • Spring提供了一個(gè)便捷的事務(wù)管理接口,適用于小型的本地事物處理(比如在單DB的環(huán)境下)和復(fù)雜的共同事物處理(比如利用JTA的復(fù)雜DB環(huán)境)。

3、什么是控制反轉(zhuǎn)(IOC)?什么是依賴注入?

  • 控制反轉(zhuǎn)是應(yīng)用于軟件工程領(lǐng)域中的,在運(yùn)行時(shí)被裝配器對象來綁定耦合對象的一種編程技巧,對象之間耦合關(guān)系在編譯時(shí)通常是未知的。在傳統(tǒng)的編程方式中,業(yè)務(wù)邏輯的流程是由應(yīng)用程序中的早已被設(shè)定好關(guān)聯(lián)關(guān)系的對象來決定的。在使用控制反轉(zhuǎn)的情況下,業(yè)務(wù)邏輯的流程是由對象關(guān)系圖來決定的,該對象關(guān)系圖由裝配器負(fù)責(zé)實(shí)例化,這種實(shí)現(xiàn)方式還可以將對象之間的關(guān)聯(lián)關(guān)系的定義抽象化。而綁定的過程是通過“依賴注入”實(shí)現(xiàn)的。

  • 控制反轉(zhuǎn)是一種以給予應(yīng)用程序中目標(biāo)組件更多控制為目的設(shè)計(jì)范式,并在我們的實(shí)際工作中起到了有效的作用。

  • 依賴注入是在編譯階段尚未知所需的功能是來自哪個(gè)的類的情況下,將其他對象所依賴的功能對象實(shí)例化的模式。這就需要一種機(jī)制用來激活相應(yīng)的組件以提供特定的功能,所以依賴注入是控制反轉(zhuǎn)的基礎(chǔ)。否則如果在組件不受框架控制的情況下,框架又怎么知道要?jiǎng)?chuàng)建哪個(gè)組件?

在Java中依然注入有以下三種實(shí)現(xiàn)方式:

  • 構(gòu)造器注入

  • Setter方法注入

  • 接口注入

  • 4、請解釋下Spring框架中的IoC?

    • Spring中的 org.springframework.beans 包和 org.springframework.context包構(gòu)成了Spring框架IoC容器的基礎(chǔ)。

    • BeanFactory 接口提供了一個(gè)先進(jìn)的配置機(jī)制,使得任何類型的對象的配置成為可能。ApplicationContex接口對BeanFactory(是一個(gè)子接口)進(jìn)行了擴(kuò)展,在BeanFactory的基礎(chǔ)上添加了其他功能,比如與Spring的AOP更容易集成,也提供了處理message resource的機(jī)制(用于國際化)、事件傳播以及應(yīng)用層的特別配置,比如針對Web應(yīng)用的WebApplicationContext。

    • org.springframework.beans.factory.BeanFactory 是Spring IoC容器的具體實(shí)現(xiàn),用來包裝和管理前面提到的各種bean。BeanFactory接口是Spring IoC 容器的核心接口。

    5、BeanFactory和ApplicationContext有什么區(qū)別?

    • BeanFactory 可以理解為含有bean集合的工廠類。BeanFactory 包含了種bean的定義,以便在接收到客戶端請求時(shí)將對應(yīng)的bean實(shí)例化。

    • BeanFactory還能在實(shí)例化對象的時(shí)生成協(xié)作類之間的關(guān)系。此舉將bean自身與bean客戶端的配置中解放出來。BeanFactory還包含了bean生命周期的控制,調(diào)用客戶端的初始化方法(initialization methods)和銷毀方法(destruction methods)。

    • 從表面上看,application context如同bean factory一樣具有bean定義、bean關(guān)聯(lián)關(guān)系的設(shè)置,根據(jù)請求分發(fā)bean的功能。但application context在此基礎(chǔ)上還提供了其他的功能。

  • 提供了支持國際化的文本消息

  • 統(tǒng)一的資源文件讀取方式

  • 已在監(jiān)聽器中注冊的bean的事件 以下是三種較常見的 ApplicationContext 實(shí)現(xiàn)方式:

  • 1、ClassPathXmlApplicationContext:從classpath的XML配置文件中讀取上下文,并生成上下文定義。應(yīng)用程序上下文從程序環(huán)境變量中取得。

    ApplicationContext context = new ClassPathXmlApplicationContext(“bean.xml”);

    2、FileSystemXmlApplicationContext :由文件系統(tǒng)中的XML配置文件讀取上下文。

    ApplicationContext context = new FileSystemXmlApplicationContext(“bean.xml”);

    3、XmlWebApplicationContext:由Web應(yīng)用的XML文件讀取上下文。

    6、Spring有幾種配置方式?

    將Spring配置到應(yīng)用開發(fā)中有以下三種方式:

  • 基于XML的配置

  • 基于注解的配置

  • 基于Java的配置

  • 7、如何用基于XML配置的方式配置Spring?

    • 在Spring框架中,依賴和服務(wù)需要在專門的配置文件來實(shí)現(xiàn),我常用的XML格式的配置文件。這些配置文件的格式通常用開頭,然后一系列的bean定義和專門的應(yīng)用配置選項(xiàng)組成。

    • SpringXML配置的主要目的時(shí)候是使所有的Spring組件都可以用xml文件的形式來進(jìn)行配置。這意味著不會(huì)出現(xiàn)其他的Spring配置類型(比如聲明的方式或基于Java Class的配置方式)

    • Spring的XML配置方式是使用被Spring命名空間的所支持的一系列的XML標(biāo)簽來實(shí)現(xiàn)的。Spring有以下主要的命名空間:context、beans、jdbc、tx、aop、mvc和aso。

    name="viewResolver" class="org.springframework.web.servlet.view.BeanNameViewResolver"/>

    name="jsonTemplate" class="org.springframework.web.servlet.view.json.MappingJackson2JsonView"/>

    id="restTemplate" class="org.springframework.web.client.RestTemplate"/>

    下面這個(gè)web.xml僅僅配置了DispatcherServlet,這件最簡單的配置便能滿足應(yīng)用程序配置運(yùn)行時(shí)組件的需求。

    Archetype Created Web Application

    spring

    org.springframework.web.servlet.DispatcherServlet

    1

    spring

    /

    8、如何用基于Java配置的方式配置Spring?

    Spring對Java配置的支持是由@Configuration注解和@Bean注解來實(shí)現(xiàn)的。由@Bean注解的方法將會(huì)實(shí)例化、配置和初始化一個(gè)新對象,這個(gè)對象將由Spring的IoC容器來管理。@Bean聲明所起到的作用與元素類似。被@Configuration所注解的類則表示這個(gè)類的主要目的是作為bean定義的資源。被@Configuration聲明的類可以通過在同一個(gè)類的內(nèi)部調(diào)用@bean方法來設(shè)置嵌入bean的依賴關(guān)系。

    最簡單的@Configuration 聲明類請參考下面的代碼:

    @Configuration

    public class AppConfig

    {

    @Bean

    public MyService myService() {

    return new MyServiceImpl();

    }

    }

    對于上面的@Beans配置文件相同的XML配置文件如下:

    id="myService" class="com.howtodoinjava.services.MyServiceImpl"/>

    上述配置方式的實(shí)例化方式如下:利用AnnotationConfigApplicationContext 類進(jìn)行實(shí)例化

    public static void main(String[] args) {

    ApplicationContext ctx = new AnnotationConfigApplicationContext(AppConfig.class);

    MyService myService = ctx.getBean(MyService.class);

    myService.doStuff();

    }

    要使用組件組建掃描,僅需用@Configuration進(jìn)行注解即可:

    @Configuration

    @ComponentScan(basePackages = "com.howtodoinjava")

    public class AppConfig {

    ...

    }

    在上面的例子中,com.acme包首先會(huì)被掃到,然后再容器內(nèi)查找被@Component 聲明的類,找到后將這些類按照Sring bean定義進(jìn)行注冊。

    如果你要在你的web應(yīng)用開發(fā)中選用上述的配置的方式的話,需要用AnnotationConfigWebApplicationContext 類來讀取配置文件,可以用來配置Spring的Servlet監(jiān)聽器ContrextLoaderListener或者Spring MVC的DispatcherServlet。

    contextClass

    org.springframework.web.context.support.AnnotationConfigWebApplicationContext

    contextConfigLocation

    com.howtodoinjava.AppConfig

    org.springframework.web.context.ContextLoaderListener

    dispatcher

    org.springframework.web.servlet.DispatcherServlet

    contextClass

    org.springframework.web.context.support.AnnotationConfigWebApplicationContext

    contextConfigLocation

    com.howtodoinjava.web.MvcConfig

    dispatcher

    /app/*

    9、怎樣用注解的方式配置Spring?

    Spring在2.5版本以后開始支持用注解的方式來配置依賴注入。可以用注解的方式來替代XML方式的bean描述,可以將bean描述轉(zhuǎn)移到組件類的內(nèi)部,只需要在相關(guān)類上、方法上或者字段聲明上使用注解即可。注解注入將會(huì)被容器在XML注入之前被處理,所以后者會(huì)覆蓋掉前者對于同一個(gè)屬性的處理結(jié)果。

    注解裝配在Spring中是默認(rèn)關(guān)閉的。所以需要在Spring文件中配置一下才能使用基于注解的裝配模式。如果你想要在你的應(yīng)用程序中使用關(guān)于注解的方法的話,請參考如下的配置。

    在標(biāo)簽配置完成以后,就可以用注解的方式在Spring中向?qū)傩浴⒎椒ê蜆?gòu)造方法中自動(dòng)裝配變量。

    下面是幾種比較重要的注解類型:

  • @Required:該注解應(yīng)用于設(shè)值方法。

  • @Autowired:該注解應(yīng)用于有值設(shè)值方法、非設(shè)值方法、構(gòu)造方法和變量。

  • @Qualifier:該注解和@Autowired注解搭配使用,用于消除特定bean自動(dòng)裝配的歧義。

  • JSR-250 Annotations:Spring支持基于JSR-250 注解的以下注解,@Resource、@PostConstruct 和 @PreDestroy。

  • 10、請解釋Spring Bean的生命周期?

    Spring Bean的生命周期簡單易懂。在一個(gè)bean實(shí)例被初始化時(shí),需要執(zhí)行一系列的初始化操作以達(dá)到可用的狀態(tài)。同樣的,當(dāng)一個(gè)bean不在被調(diào)用時(shí)需要進(jìn)行相關(guān)的析構(gòu)操作,并從bean容器中移除。

    Spring bean factory 負(fù)責(zé)管理在spring容器中被創(chuàng)建的bean的生命周期。Bean的生命周期由兩組回調(diào)(call back)方法組成。

  • 初始化之后調(diào)用的回調(diào)方法。

  • 銷毀之前調(diào)用的回調(diào)方法。

  • Spring框架提供了以下四種方式來管理bean的生命周期事件:

    • InitializingBean和DisposableBean回調(diào)接口

    • 針對特殊行為的其他Aware接口

    • Bean配置文件中的Custom init()方法和destroy()方法

    • @PostConstruct和@PreDestroy注解方式

    • 使用customInit()和

    customDestroy()方法管理bean生命周期的代碼樣例如下:

    id="demoBean" class="com.howtodoinjava.task.DemoBean"

    init-method="customInit" destroy-method="customDestroy">

    更多內(nèi)容請參考:Spring生命周期Spring Bean Life Cycle。

    https://howtodoinjava.com/spring-core/spring-bean-life-cycle/

    11、Spring Bean的作用域之間有什么區(qū)別?

    Spring容器中的bean可以分為5個(gè)范圍。所有范圍的名稱都是自說明的,但是為了避免混淆,還是讓我們來解釋一下:

  • singleton:這種bean范圍是默認(rèn)的,這種范圍確保不管接受到多少個(gè)請求,每個(gè)容器中只有一個(gè)bean的實(shí)例,單例的模式由bean factory自身來維護(hù)。

  • prototype:原形范圍與單例范圍相反,為每一個(gè)bean請求提供一個(gè)實(shí)例。

  • request:在請求bean范圍內(nèi)會(huì)每一個(gè)來自客戶端的網(wǎng)絡(luò)請求創(chuàng)建一個(gè)實(shí)例,在請求完成以后,bean會(huì)失效并被垃圾回收器回收。

  • Session:與請求范圍類似,確保每個(gè)session中有一個(gè)bean的實(shí)例,在session過期后,bean會(huì)隨之失效。

  • global-session:global-session和Portlet應(yīng)用相關(guān)。當(dāng)你的應(yīng)用部署在Portlet容器中工作時(shí),它包含很多portlet。如果你想要聲明讓所有的portlet共用全局的存儲變量的話,那么這全局變量需要存儲在global-session中。

  • 全局作用域與Servlet中的session作用域效果相同。

    更多內(nèi)容請參考 : Spring Bean Scopes。

    https://howtodoinjava.com/spring-core/spring-bean-scopes/

    12、什么是Spring inner beans?

    在Spring框架中,無論何時(shí)bean被使用時(shí),當(dāng)僅被調(diào)用了一個(gè)屬性。一個(gè)明智的做法是將這個(gè)bean聲明為內(nèi)部bean。內(nèi)部bean可以用setter注入“屬性”和構(gòu)造方法注入“構(gòu)造參數(shù)”的方式來實(shí)現(xiàn)。

    比如,在我們的應(yīng)用程序中,一個(gè)Customer類引用了一個(gè)Person類,我們的要做的是創(chuàng)建一個(gè)Person的實(shí)例,然后在Customer內(nèi)部使用。

    public class Customer

    {

    private Person person;

    //Setters and Getters

    }

    public class Person

    {

    private String name;

    private String address;

    private int age;

    //Setters and Getters

    }

    內(nèi)部bean的聲明方式如下:

    id="CustomerBean" class="com.howtodoinjava.common.Customer">

    name="person">

    class="com.howtodoinjava.common.Person">

    name="name" value="lokesh" />

    name="address" value="India" />

    name="age" value="34" />

    13、Spring框架中的單例Beans是線程安全的么?

    • Spring框架并沒有對單例bean進(jìn)行任何多線程的封裝處理。關(guān)于單例bean的線程安全和并發(fā)問題需要開發(fā)者自行去搞定。但實(shí)際上,大部分的Spring bean并沒有可變的狀態(tài)(比如Serview類和DAO類),所以在某種程度上說Spring的單例bean是線程安全的。如果你的bean有多種狀態(tài)的話(比如 View Model 對象),就需要自行保證線程安全。

    • 最淺顯的解決辦法就是將多態(tài)bean的作用域由“singleton”變更為“prototype”。

    14、請舉例說明如何在Spring中注入一個(gè)Java Collection?

    Spring提供了以下四種集合類的配置元素:

    • : 該標(biāo)簽用來裝配可重復(fù)的list值。

    • : 該標(biāo)簽用來裝配沒有重復(fù)的set值。

    -?: 該標(biāo)簽支持注入鍵和值都是字符串類型的鍵值對。

    下面看一下具體的例子:

    id="javaCollection" class="com.howtodoinjava.JavaCollection">

    name="customList">

    INDIA

    Pakistan

    USA

    UK

    name="customSet">

    INDIA

    Pakistan

    USA

    UK

    name="customMap">

    key="1" value="INDIA"/>

    key="2" value="Pakistan"/>

    key="3" value="USA"/>

    key="4" value="UK"/>

    name="customProperies">

    key="admin">admin@nospam.com

    key="support">support@nospam.com

    15、如何向Spring Bean中注入一個(gè)Java.util.Properties?

    第一種方法是使用如下面代碼所示的標(biāo)簽:

    id="adminUser" class="com.howtodoinjava.common.Customer">

    name="emails">

    key="admin">admin@nospam.com

    key="support">support@nospam.com

    也可用”util:”命名空間來從properties文件中創(chuàng)建出一個(gè)propertiesbean,然后利用setter方法注入bean的引用。

    16、請解釋Spring Bean的自動(dòng)裝配?

    在Spring框架中,在配置文件中設(shè)定bean的依賴關(guān)系是一個(gè)很好的機(jī)制,Spring容器還可以自動(dòng)裝配合作關(guān)系bean之間的關(guān)聯(lián)關(guān)系。這意味著Spring可以通過向Bean Factory中注入的方式自動(dòng)搞定bean之間的依賴關(guān)系。自動(dòng)裝配可以設(shè)置在每個(gè)bean上,也可以設(shè)定在特定的bean上。

    下面的XML配置文件表明了如何根據(jù)名稱將一個(gè)bean設(shè)置為自動(dòng)裝配:

    id="employeeDAO" class="com.howtodoinjava.EmployeeDAOImpl" autowire="byName" />

    除了bean配置文件中提供的自動(dòng)裝配模式,還可以使用@Autowired注解來自動(dòng)裝配指定的bean。在使用@Autowired注解之前需要在按照如下的配置方式在Spring配置文件進(jìn)行配置才可以使用。

    />

    也可以通過在配置文件中配置AutowiredAnnotationBeanPostProcessor 達(dá)到相同的效果。

    class ="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/>

    配置好以后就可以使用@Autowired來標(biāo)注了。

    @Autowired

    public EmployeeDAOImpl ( EmployeeManager manager ) {

    this.manager = manager;

    }

    17、請解釋自動(dòng)裝配模式的區(qū)別?

    在Spring框架中共有5種自動(dòng)裝配,讓我們逐一分析。

  • no:這是Spring框架的默認(rèn)設(shè)置,在該設(shè)置下自動(dòng)裝配是關(guān)閉的,開發(fā)者需要自行在bean定義中用標(biāo)簽明確的設(shè)置依賴關(guān)系。

  • byName:該選項(xiàng)可以根據(jù)bean名稱設(shè)置依賴關(guān)系。當(dāng)向一個(gè)bean中自動(dòng)裝配一個(gè)屬性時(shí),容器將根據(jù)bean的名稱自動(dòng)在在配置文件中查詢一個(gè)匹配的bean。如果找到的話,就裝配這個(gè)屬性,如果沒找到的話就報(bào)錯(cuò)。

  • byType:該選項(xiàng)可以根據(jù)bean類型設(shè)置依賴關(guān)系。當(dāng)向一個(gè)bean中自動(dòng)裝配一個(gè)屬性時(shí),容器將根據(jù)bean的類型自動(dòng)在在配置文件中查詢一個(gè)匹配的bean。如果找到的話,就裝配這個(gè)屬性,如果沒找到的話就報(bào)錯(cuò)。

  • constructor:造器的自動(dòng)裝配和byType模式類似,但是僅僅適用于與有構(gòu)造器相同參數(shù)的bean,如果在容器中沒有找到與構(gòu)造器參數(shù)類型一致的bean,那么將會(huì)拋出異常。

  • autodetect:該模式自動(dòng)探測使用構(gòu)造器自動(dòng)裝配或者byType自動(dòng)裝配。首先,首先會(huì)嘗試找合適的帶參數(shù)的構(gòu)造器,如果找到的話就是用構(gòu)造器自動(dòng)裝配,如果在bean內(nèi)部沒有找到相應(yīng)的構(gòu)造器或者是無參構(gòu)造器,容器就會(huì)自動(dòng)選擇byTpe的自動(dòng)裝配方式。

  • 18、如何開啟基于注解的自動(dòng)裝配?

    要使用 @Autowired,需要注冊 AutowiredAnnotationBeanPostProcessor,可以有以下兩種方式來實(shí)現(xiàn):

    1、引入配置文件中的下引入

    />

    2、在bean配置文件中直接引入AutowiredAnnotationBeanPostProcessor

    class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/>

    19、請舉例解釋@Required注解?

    在產(chǎn)品級別的應(yīng)用中,IoC容器可能聲明了數(shù)十萬了bean,bean與bean之間有著復(fù)雜的依賴關(guān)系。設(shè)值注解方法的短板之一就是驗(yàn)證所有的屬性是否被注解是一項(xiàng)十分困難的操作。可以通過在中設(shè)置“dependency-check”來解決這個(gè)問題。

    在應(yīng)用程序的生命周期中,你可能不大愿意花時(shí)間在驗(yàn)證所有bean的屬性是否按照上下文文件正確配置。或者你寧可驗(yàn)證某個(gè)bean的特定屬性是否被正確的設(shè)置。即使是用“dependency-check”屬性也不能很好的解決這個(gè)問題,在這種情況下,你需要使用@Required 注解。

    需要用如下的方式使用來標(biāo)明bean的設(shè)值方法。

    public class EmployeeFactoryBean extends AbstractFactoryBean<Object>

    {

    private String designation;

    public String getDesignation() {

    return designation;

    }

    @Required

    public void setDesignation(String designation) {

    this.designation = designation;

    }

    //more code here

    }

    RequiredAnnotationBeanPostProcessor是Spring中的后置處理用來驗(yàn)證被@Required 注解的bean屬性是否被正確的設(shè)置了。在使用RequiredAnnotationBeanPostProcesso來驗(yàn)證bean屬性之前,首先要在IoC容器中對其進(jìn)行注冊:

    class="org.springframework.beans.factory.annotation.RequiredAnnotationBeanPostProcessor" />

    但是如果沒有屬性被用 @Required 注解過的話,后置處理器會(huì)拋出一個(gè)BeanInitializationException 異常。

    20、請舉例解釋@Autowired注解?

    @Autowired注解對自動(dòng)裝配何時(shí)何處被實(shí)現(xiàn)提供了更多細(xì)粒度的控制。@Autowired注解可以像@Required注解、構(gòu)造器一樣被用于在bean的設(shè)值方法上自動(dòng)裝配bean的屬性,一個(gè)參數(shù)或者帶有任意名稱或帶有多個(gè)參數(shù)的方法。

    比如,可以在設(shè)值方法上使用@Autowired注解來替代配置文件中的元素。當(dāng)Spring容器在setter方法上找到@Autowired注解時(shí),會(huì)嘗試用byType 自動(dòng)裝配。

    當(dāng)然我們也可以在構(gòu)造方法上使用@Autowired 注解。帶有@Autowired 注解的構(gòu)造方法意味著在創(chuàng)建一個(gè)bean時(shí)將會(huì)被自動(dòng)裝配,即便在配置文件中使用 元素。

    public class TextEditor {

    private SpellChecker spellChecker;

    @Autowired

    public TextEditor(SpellChecker spellChecker){

    System.out.println("Inside TextEditor constructor." );

    this.spellChecker = spellChecker;

    }

    public void spellCheck(){

    spellChecker.checkSpelling();

    }

    }

    下面是沒有構(gòu)造參數(shù)的配置方式:

    id="textEditor" class="com.howtodoinjava.TextEditor">

    id="spellChecker" class="com.howtodoinjava.SpellChecker">

    21、請舉例說明@Qualifier注解?

    @Qualifier注解意味著可以在被標(biāo)注bean的字段上可以自動(dòng)裝配。Qualifier注解可以用來取消Spring不能取消的bean應(yīng)用。

    下面的示例將會(huì)在Customer的person屬性中自動(dòng)裝配person的值。

    public class Customer

    {

    @Autowired

    private Person person;

    }

    下面我們要在配置文件中來配置Person類。

    id="customer" class="com.howtodoinjava.common.Customer" />

    id="personA" class="com.howtodoinjava.common.Person" >

    name="name" value="lokesh" />

    id="personB" class="com.howtodoinjava.common.Person" >

    name="name" value="alex" />

    Spring會(huì)知道要自動(dòng)裝配哪個(gè)person bean么?不會(huì)的,但是運(yùn)行上面的示例時(shí),會(huì)拋出下面的異常:

    Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException:

    No unique bean of type [com.howtodoinjava.common.Person] is defined:

    expected single matching bean but found 2: [personA, personB]

    要解決上面的問題,需要使用 @Quanlifier注解來告訴Spring容器要裝配哪個(gè)bean:

    public class Customer

    {

    @Autowired

    @Qualifier("personA")

    private Person person;

    }

    22、構(gòu)造方法注入和設(shè)值注入有什么區(qū)別?

    請注意以下明顯的區(qū)別:

  • 在設(shè)值注入方法支持大部分的依賴注入,如果我們僅需要注入int、string和long型的變量,我們不要用設(shè)值的方法注入。對于基本類型,如果我們沒有注入的話,可以為基本類型設(shè)置默認(rèn)值。在構(gòu)造方法注入不支持大部分的依賴注入,因?yàn)樵谡{(diào)用構(gòu)造方法中必須傳入正確的構(gòu)造參數(shù),否則的話為報(bào)錯(cuò)。

  • 設(shè)值注入不會(huì)重寫構(gòu)造方法的值。如果我們對同一個(gè)變量同時(shí)使用了構(gòu)造方法注入又使用了設(shè)置方法注入的話,那么構(gòu)造方法將不能覆蓋由設(shè)值方法注入的值。很明顯,因?yàn)闃?gòu)造方法盡在對象被創(chuàng)建時(shí)調(diào)用。

  • 在使用設(shè)值注入時(shí)有可能還不能保證某種依賴是否已經(jīng)被注入,也就是說這時(shí)對象的依賴關(guān)系有可能是不完整的。而在另一種情況下,構(gòu)造器注入則不允許生成依賴關(guān)系不完整的對象。

  • 在設(shè)值注入時(shí)如果對象A和對象B互相依賴,在創(chuàng)建對象A時(shí)Spring會(huì)拋出sObjectCurrentlyInCreationException異常,因?yàn)樵贐對象被創(chuàng)建之前A對象是不能被創(chuàng)建的,反之亦然。所以Spring用設(shè)值注入的方法解決了循環(huán)依賴的問題,因?qū)ο蟮脑O(shè)值方法是在對象被創(chuàng)建之前被調(diào)用的。

  • 23、Spring框架中有哪些不同類型的事件?

    Spring的ApplicationContext 提供了支持事件和代碼中監(jiān)聽器的功能。 我們可以創(chuàng)建bean用來監(jiān)聽在ApplicationContext 中發(fā)布的事件。ApplicationEvent類和在ApplicationContext接口中處理的事件,如果一個(gè)bean實(shí)現(xiàn)了ApplicationListener接口,當(dāng)一個(gè)ApplicationEvent 被發(fā)布以后,bean會(huì)自動(dòng)被通知。

    public class AllApplicationEventListener implements ApplicationListener < ApplicationEvent >

    {

    @Override

    public void onApplicationEvent(ApplicationEvent applicationEvent)

    {

    //process event

    }

    }

    Spring 提供了以下5中標(biāo)準(zhǔn)的事件:

  • 上下文更新事件(ContextRefreshedEvent):該事件會(huì)在ApplicationContext被初始化或者更新時(shí)發(fā)布。也可以在調(diào)用ConfigurableApplicationContext 接口中的refresh()方法時(shí)被觸發(fā)。

  • 上下文開始事件(ContextStartedEvent):當(dāng)容器調(diào)用ConfigurableApplicationContext的Start()方法開始/重新開始容器時(shí)觸發(fā)該事件。

  • 上下文停止事件(ContextStoppedEvent):當(dāng)容器調(diào)用ConfigurableApplicationContext的Stop()方法停止容器時(shí)觸發(fā)該事件。

  • 上下文關(guān)閉事件(ContextClosedEvent):當(dāng)ApplicationContext被關(guān)閉時(shí)觸發(fā)該事件。容器被關(guān)閉時(shí),其管理的所有單例Bean都被銷毀。

  • 請求處理事件(RequestHandledEvent):在Web應(yīng)用中,當(dāng)一個(gè)http請求(request)結(jié)束觸發(fā)該事件。

  • 除了上面介紹的事件以外,還可以通過擴(kuò)展ApplicationEvent 類來開發(fā)自定義的事件。

    public class CustomApplicationEvent extends ApplicationEvent

    {

    public CustomApplicationEvent ( Object source, final String msg )

    {

    super(source);

    System.out.println("Created a Custom event");

    }

    }

    為了監(jiān)聽這個(gè)事件,還需要?jiǎng)?chuàng)建一個(gè)監(jiān)聽器:

    public class CustomEventListener implements ApplicationListener < CustomApplicationEvent >

    {

    @Override

    public void onApplicationEvent(CustomApplicationEvent applicationEvent) {

    //handle event

    }

    }

    之后通過applicationContext接口的publishEvent()方法來發(fā)布自定義事件。

    CustomApplicationEvent customEvent = new CustomApplicationEvent(applicationContext, "Test message");

    applicationContext.publishEvent(customEvent);

    24、FileSystemResource和ClassPathResource有何區(qū)別?

    在FileSystemResource中需要給出spring-config.xml文件在你項(xiàng)目中的相對路徑或者絕對路徑。在ClassPathResource中spring會(huì)在ClassPath中自動(dòng)搜尋配置文件,所以要把ClassPathResource 文件放在ClassPath下。

    如果將spring-config.xml保存在了src文件夾下的話,只需給出配置文件的名稱即可,因?yàn)閟rc文件夾是默認(rèn)。

    簡而言之,ClassPathResource在環(huán)境變量中讀取配置文件,FileSystemResource在配置文件中讀取配置文件。

    25、Spring 框架中都用到了哪些設(shè)計(jì)模式?

    Spring框架中使用到了大量的設(shè)計(jì)模式,下面列舉了比較有代表性的:

  • 代理模式—在AOP和remoting中被用的比較多。

  • 單例模式—在spring配置文件中定義的bean默認(rèn)為單例模式。

  • 模板方法—用來解決代碼重復(fù)的問題。比如. RestTemplate, JmsTemplate, JpaTemplate。

  • 前端控制器—Spring提供了DispatcherServlet來對請求進(jìn)行分發(fā)。

  • 視圖幫助(View Helper )—Spring提供了一系列的JSP標(biāo)簽,高效宏來輔助將分散的代碼整合在視圖里。

  • 依賴注入—貫穿于BeanFactory / ApplicationContext接口的核心理念。

  • 工廠模式—BeanFactory用來創(chuàng)建對象的實(shí)例。

  • END

    覺得文章不錯(cuò)的,歡迎點(diǎn)好看轉(zhuǎn)發(fā),長按下圖關(guān)注公眾號?程序員喬戈里,收看更多精彩。

    今日問題:Spring你覺得它在面試中地位如何?歡迎留言

    總結(jié)

    以上是生活随笔為你收集整理的osgi框架和spring区别_BATJ面试必会之 Spring 篇(二)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。