天天看點

一些ssh面試題及答案

Hibernate工作原理及為什麼要用?

原理:

1.讀取并解析配置檔案

2.讀取并解析映射資訊,建立SessionFactory

3.打開Sesssion

4.建立事務Transation

5.持久化操作

6.送出事務

7.關閉Session

8.關閉SesstionFactory

為什麼要用:

1. 對JDBC通路資料庫的代碼做了封裝,大大簡化了資料通路層繁瑣的重複性代碼。

2. Hibernate是一個基于JDBC的主流持久化架構,是一個優秀的ORM實作。他很大程度的簡化DAO層的編碼工作

3. hibernate使用Java反射機制,而不是位元組碼增強程式來實作透明性。

4. hibernate的性能非常好,因為它是個輕量級架構。映射的靈活性很出色。它支援各種關系資料庫,從一對一到多對多的各種複雜關系。

2. Hibernate是如何延遲加載?

1. Hibernate2延遲加載實作:a)實體對象 b)集合(Collection)

2. Hibernate3 提供了屬性的延遲加載功能

當Hibernate在查詢資料的時候,資料并沒有存在與記憶體中,當程式真正對資料的操作時,對象才存在與記憶體中,就實作了延遲加載,他節省了伺服器的記憶體開銷,進而提高了伺服器的性能。

3.Hibernate中怎樣實作類之間的關系?(如:一對多、多對多的關系)

類與類之間的關系主要展現在表與表之間的關系進行操作,它們都市對對象進行操作,我們程式中把所有的表與類都映射在一起,它們通過配置檔案中的many-to-one、one-to-many、many-to-many、

4. 說下Hibernate的緩存機制

1. 内部緩存存在Hibernate中又叫一級緩存,屬于應用事物級緩存

2. 二級緩存:

a) 應用及緩存

b) 分布式緩存

條件:資料不會被第三方修改、資料大小在可接受範圍、資料更新頻率低、同一資料被系統頻繁使用、非 關鍵資料

c) 第三方緩存的實作

5. Hibernate的查詢方式

Sql、Criteria,object comptosition

Hql:

1、 屬性查詢

2、 參數查詢、命名參數查詢

3、 關聯查詢

4、 分頁查詢

5、 統計函數

6. 如何優化Hibernate?

1.使用雙向一對多關聯,不使用單向一對多

2.靈活使用單向一對多關聯

3.不用一對一,用多對一取代

4.配置對象緩存,不使用集合緩存

5.一對多集合使用Bag,多對多集合使用Set

6. 繼承類使用顯式多态

7. 表字段要少,表關聯不要怕多,有二級緩存撐腰

7. Struts工作機制?為什麼要使用Struts?

工作機制:

Struts的工作流程:

在web應用啟動時就會加載初始化ActionServlet,ActionServlet從

struts-config.xml檔案中讀取配置資訊,把它們存放到各種配置對象

當ActionServlet接收到一個客戶請求時,将執行如下流程.

-(1)檢索和使用者請求比對的ActionMapping執行個體,如果不存在,就傳回請求路徑無效資訊;

-(2)如果ActionForm執行個體不存在,就建立一個ActionForm對象,把客戶送出的表單資料儲存到ActionForm對象中;

-(3)根據配置資訊決定是否需要表單驗證.如果需要驗證,就調用ActionForm的validate()方法;

-(4)如果ActionForm的validate()方法傳回null或傳回一個不包含ActionMessage的ActuibErrors對象, 就表示表單驗證成功;

-(5)ActionServlet根據ActionMapping所包含的映射資訊決定将請求轉發給哪個Action,如果相應的 Action執行個體不存在,就先建立這個執行個體,然後調用Action的execute()方法;

-(6)Action的execute()方法傳回一個ActionForward對象,ActionServlet在把客戶請求轉發給 ActionForward對象指向的JSP元件;

-(7)ActionForward對象指向JSP元件生成動态網頁,傳回給客戶;

為什麼要用:

JSP、Servlet、JavaBean技術的出現給我們建構強大的企業應用系統提供了可能。但用這些技術建構的系統非常的繁亂,是以在此之上,我們需要一個規則、一個把這些技術組織起來的規則,這就是架構,Struts便應運而生。

基于Struts開發的應用由3類元件構成:控制器元件、模型元件、視圖元件

8. Struts的validate架構是如何驗證的?

在struts配置檔案中配置具體的錯誤提示,再在FormBean中的validate()方法具體調用。

9. 說下Struts的設計模式

MVC模式: web應用程式啟動時就會加載并初始化ActionServler。使用者送出表單時,一個配置好的ActionForm對象被建立,并被填入表單相應的資料,ActionServler根據Struts-config.xml檔案配置好的設定決定是否需要表單驗證,如果需要就調用ActionForm的 Validate()驗證後選擇将請求發送到哪個Action,如果Action不存在,ActionServlet會先建立這個對象,然後調用 Action的execute()方法。Execute()從ActionForm對象中擷取資料,完成業務邏輯,傳回一個ActionForward對象,ActionServlet再把客戶請求轉發給ActionForward對象指定的jsp元件,ActionForward對象指定的jsp生成動态的網頁,傳回給客戶。

10. spring工作機制及為什麼要用?

1.spring mvc請所有的請求都送出給DispatcherServlet,它會委托應用系統的其他子產品負責負責對請求進行真正的處理工作。

2.DispatcherServlet查詢一個或多個HandlerMapping,找到處理請求的Controller.

3.DispatcherServlet請請求送出到目标Controller

4.Controller進行業務邏輯處理後,會傳回一個ModelAndView

5.Dispathcher查詢一個或多個ViewResolver視圖解析器,找到ModelAndView對象指定的視圖對象

6.視圖對象負責渲染傳回給用戶端。

為什麼用:

{AOP 讓開發人員可以建立非行為性的關注點,稱為橫切關注點,并将它們插入到應用程式代碼中。使用 AOP 後,公共服務 (比如日志、持久性、事務等)就可以分解成方面并應用到域對象上,同時不會增加域對象的對象模型的複雜性。

IOC 允許建立一個可以構造對象的應用環境,然後向這些對象傳遞它們的協作對象。正如單詞 倒置 所表明的,IOC 就像反 過來的 JNDI。沒有使用一堆抽象工廠、服務定位器、單元素(singleton)和直接構造(straight construction),每一個對象都是用其協作對象構造的。是以是由容器管理協作對象(collaborator)。

Spring即使一個AOP架構,也是一IOC容器。 Spring 最好的地方是它有助于您替換對象。有了 Spring,隻要用 JavaBean 屬性和配置檔案加入依賴性(協作對象)。然後可以很容易地在需要時替換具有類似接口的協作對象。}

Spring 架構是一個分層架構,由 7 個定義良好的子產品組成。Spring 子產品建構在核心容器之上,核心容器定義了建立、配置和管理 bean 的方式,如圖 1 所示。

組成 Spring 架構的每個子產品(或元件)都可以單獨存在,或者與其他一個或多個子產品聯合實作。每個子產品的功能如下:

☆ 核心容器:核心容器提供 Spring 架構的基本功能。核心容器的主要元件是 BeanFactory,它是工廠模式的實作。BeanFactory 使用控制反轉 (IOC)模式将應用程式的配置和依賴性規範與實際的應用程式代碼分開。

☆ Spring 上下文:Spring 上下文是一個配置檔案,向 Spring 架構提供上下文資訊。Spring 上下文包括企業服務,例如 JNDI、EJB、電子郵件、國際化、校驗和排程功能。

☆ Spring AOP:通過配置管理特性,Spring AOP 子產品直接将面向方面的程式設計功能內建到了 Spring 架構中。是以,可以很容易地使 Spring 架構管理的任何對象支援 AOP。Spring AOP 子產品為基于 Spring 的應用程式中的對象提供了事務管理服務。通過使用 Spring AOP,不用依賴 EJB 元件,就可以将聲明性事務管理內建到應用程式中。

☆ Spring DAO:JDBC DAO 抽象層提供了有意義的異常層次結構,可用該結構來管理異常處理和不同資料庫供應商抛出的錯誤消息。異常層次結構簡化了錯誤處理,并且極大地降低了需要編寫的異常代碼數量(例如打開和關閉連接配接)。Spring DAO 的面向 JDBC 的異常遵從通用的 DAO 異常層次結構。

☆ Spring ORM:Spring 架構插入了若幹個 ORM 架構,進而提供了 ORM 的對象關系工具,其中包括 JDO、Hibernate 和 iBatis SQL Map。所有這些都遵從 Spring 的通用事務和 DAO 異常層次結構。

☆ Spring Web 子產品:Web 上下文子產品建立在應用程式上下文子產品之上,為基于 Web 的應用程式提供了上下文。是以,Spring 架構支援與 Jakarta Struts 的內建。Web 子產品還簡化了處理多部分請求以及将請求參數綁定到域對象的工作。

☆ Spring MVC 架構:MVC 架構是一個全功能的建構 Web 應用程式的 MVC 實作。通過政策接口,MVC 架構變成為高度可配置的,MVC 容納了大量視圖技術,其中包括 JSP、Velocity、Tiles、iText 和 POI。

Spring 架構的功能可以用在任何 J2EE 伺服器中,大多數功能也适用于不受管理的環境。Spring 的核心要點是:支援不綁定到特定 J2EE 服務的可重用業務和資料通路對象。毫無疑問,這樣的對象可以在不同 J2EE 環境 (Web 或 EJB)、獨立應用程式、測試環境之間重用。

IOC 和 AOP

控制反轉模式(也稱作依賴性介入)的基本概念是:不建立對象,但是描述建立它們的方式。在代碼中不直接與對象和服務連接配接,但在配置檔案中描述哪一個元件需要哪一項服務。容器(在 Spring 架構中是 IOC 容器) 負責将這些聯系在一起。

在典型的 IOC 場景中,容器建立了所有對象,并設定必要的屬性将它們連接配接在一起,決定什麼時間調用方法。下表列出了 IOC 的一個實作模式。

Spring 架構的 IOC 容器采用類型 2 和類型3 實作。

面向方面的程式設計

面向方面的程式設計,即 AOP,是一種程式設計技術,它允許程式員對橫切關注點或橫切典型的職責分界線的行為(例如日志和事務管理)進行子產品化。AOP 的核心構造是方面,它将那些影響多個類的行為封裝到可重用的子產品中。

AOP 和 IOC 是補充性的技術,它們都運用子產品化方式解決企業應用程式開發中的複雜問題。在典型的面向對象開發方式中,可能要将日志記錄語句放在所有方法和 Java 類中才能實作日志功能。在 AOP 方式中,可以反過來将日志服務子產品化,并以聲明的方式将它們應用到需要日志的元件上。當然,優勢就是 Java 類不需要知道日志服務的存在,也不需要考慮相關的代碼。是以,用 Spring AOP 編寫的應用程式代碼是松散耦合的。

AOP 的功能完全內建到了 Spring 事務管理、日志和其他各種特性的上下文中。

IOC 容器

Spring 設計的核心是 org.springframework.beans 包,它的設計目标是與 JavaBean 元件一起使用。這個包通常不是由使用者直接使用,而是由伺服器将其用作其他多數功能的底層中介。下一個最進階抽象是 BeanFactory 接口,它是工廠設計模式的實作,允許通過名稱建立和檢索對象。BeanFactory 也可以管理對象之間的關系。

BeanFactory 支援兩個對象模型。

□ 單态 模型提供了具有特定名稱的對象的共享執行個體,可以在查詢時對其進行檢索。Singleton 是預設的也是最常用的對象模型。對于無狀态服務對象很理想。

□ 原型 模型確定每次檢索都會建立單獨的對象。在每個使用者都需要自己的對象時,原型模型最适合。

bean 工廠的概念是 Spring 作為 IOC 容器的基礎。IOC 将處理事情的責任從應用程式代碼轉移到架構。正如我将在下一個示例中示範的那樣,Spring 架構使用 JavaBean 屬性和配置資料來指出必須設定的依賴關系。

BeanFactory 接口

因為 org.springframework.beans.factory.BeanFactory 是一個簡單接口,是以可以針對各種底層存儲方法實作。最常用的 BeanFactory 定義是 XmlBeanFactory,它根據 XML 檔案中的定義裝入 bean,如清單 1 所示。

清單 1. XmlBeanFactory

BeanFactory factory = new XMLBeanFactory(new FileInputSteam("mybean.xml"));

在 XML 檔案中定義的 Bean 是被消極加載的,這意味在需要 bean 之前,bean 本身不會被初始化。要從 BeanFactory 檢索 bean,隻需調用 getBean() 方法,傳入将要檢索的 bean 的名稱即可,如清單 2 所示。

清單 2. getBean()

MyBean mybean = (MyBean) factory.getBean("mybean");

每個 bean 的定義都可以是 POJO (用類名和 JavaBean 初始化屬性定義) 或 FactoryBean。FactoryBean 接口為使用 Spring 架構建構的應用程式添加了一個間接的級别。

IOC 示例

了解控制反轉最簡單的方式就是看它的實際應用。在對由三部分組成的 Spring 系列 的第 1 部分進行總結時,我使用了一個示例,示範了如何通過 Spring IOC 容器注入應用程式的依賴關系(而不是将它們建構進來)。

我用開啟線上信用帳戶的用例作為起點。對于該實作,開啟信用帳戶要求使用者與以下服務進行互動:

☆ 信用級别評定服務,查詢使用者的信用曆史資訊。

☆ 遠端資訊連結服務,插入客戶資訊,将客戶資訊與信用卡和銀行資訊連接配接起來,以進行自動借記(如果需要的話)。

☆ 電子郵件服務,向使用者發送有關信用卡狀态的電子郵件。

三個接口

對于這個示例,我假設服務已經存在,理想的情況是用松散耦合的方式把它們內建在一起。以下清單顯示了三個服務的應用程式接口。

清單 3. CreditRatingInterface

public interface CreditRatingInterface {

public boolean getUserCreditHistoryInformation(ICustomer iCustomer);

}

清單 3 所示的信用級别評定接口提供了信用曆史資訊。它需要一個包含客戶資訊的 Customer 對象。該接口的實作是由 CreditRating 類提供的。

清單 4. CreditLinkingInterface

public interface CreditLinkingInterface {

public String getUrl();

public void setUrl(String url);

public void linkCreditBankAccount() throws Exception ;

}

信用連結接口将信用曆史資訊與銀行資訊(如果需要的話)連接配接在一起,并插入使用者的信用卡資訊。信用連結接口是一個遠端服務,它的查詢是通過 getUrl() 方法進行的。URL 由 Spring 架構的 bean 配置機制設定,我稍後會讨論它。該接口的實作是由 CreditLinking 類提供的。

清單 5. EmailInterface

public interface EmailInterface {

public void sendEmail(ICustomer iCustomer);

public String getFromEmail();

public void setFromEmail(String fromEmail) ;

public String getPassword();

public void setPassword(String password) ;

public String getSmtpHost() ;

public void setSmtpHost(String smtpHost);

public String getUserId() ;

public void setUserId(String userId); 轉載:本文出自 51CTO.COM技術部落格

繼續閱讀