<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Java Studing

    Java有我,我有Java
    數據加載中……

    2010年8月31日

    Struts、Hibernate、Spring經典面試題收藏

    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

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

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

    清單 2. getBean()

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

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

    IOC 示例

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

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

    ☆ 信用級別評定服務,查詢用戶的信用歷史信息。

    ☆ 遠程信息鏈接服務,插入客戶信息,將客戶信息與信用卡和銀行信息連接起來,以進行自動借記(如果需要的話)。

    ☆ 電子郵件服務,向用戶發送有關信用卡狀態的電子郵件。

    三個接口

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

    清單 3. CreditRatingInterface

    1. public interface CreditRatingInterface {   
    2. public boolean getUserCreditHistoryInformation(ICustomer iCustomer);    
    3. }  

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

    清單 4. CreditLinkingInterface

    1. public interface CreditLinkingInterface {   
    2.   
    3. public String getUrl();    
    4. public void setUrl(String url);    
    5. public void linkCreditBankAccount() throws Exception ;    
    6.   
    7. }   

    信用鏈接接口將信用歷史信息與銀行信息(如果需要的話)連接在一起,并插入用戶的信用卡信息。信用鏈接接口是一個遠程服務,它的查詢是通過 getUrl() 方法進行的。URL 由 Spring 框架的 bean 配置機制設置,我稍后會討論它。該接口的實現是由 CreditLinking 類提供的。

    清單 5. EmailInterface

    1. public interface EmailInterface {   
    2. public void sendEmail(ICustomer iCustomer);    
    3. public String getFromEmail();    
    4. public void setFromEmail(String fromEmail) ;    
    5. public String getPassword();    
    6. public void setPassword(String password) ;    
    7. public String getSmtpHost() ;    
    8. public void setSmtpHost(String smtpHost);    
    9. public String getUserId() ;    
    10. public void setUserId(String userId);   
    11. }  

    posted @ 2010-10-09 15:56 飛龍劍 閱讀(169) | 評論 (0)編輯 收藏
    java讀書筆記

    java體系
         一、java基礎
              1、概念 2、集合類 3、java多線程編程 4、java I/O編程 5、java網絡編程

         二、web編程
              1、html ,js,ajax,css
              2、jsp
              3、servlet
              4、jstl
              5、EL
     
         三、開源框架
              1、表示層(structs,jsf。。。)
              2、影射層(hibanate、ibatis)
              3、容器管理層(spring)


    java集合編程
         一、線性結構
              1、List(ArryList【數組】、LinkedList【鏈表】)
              2、Set(HashSet【散列集合】、TreeSet【排序】)
         二、非線性結構
              1、map(HashMap、TreeMap)
              2、HashTable(多線程)
     
     總結:
          1、上溯造型的安全性高,下溯造型的安全性低
          2、一切對象都繼承Object
          3、泛型:泛型泛指一切對象,但是泛型的缺點就是太局限用一種指定的對象
          4、集合的遍歷,集合器遍歷:
               while(it.hashNext()){
                    it.next();
               }


    【20100910】

    一、面向對象編程  
             1.類的概念
                  class是一種對象的基本類

             2.對象的概念
                  是類的一個實例, 狀態和行為,屬性和方法
             3.對象的通信:對象與對象之間的一種交互
                  a.接受消息的對象
                  b.方法(介質)
                  c.參數
             4.面向對象的特性
                  a.封裝性:對外界隱藏數據,提供一個接口用于其他對象的訪問。訪問權限(private:私有的,只有在本類才可以訪問;“有元”是只有在包中能訪問。protected用于繼承中起保護;public公共,任何對象都可以訪問。
                  b.繼承性:抽象類:不能實例化;
                  c.抽象性:

             5.接口(interface)的概念:接口可以多繼承,類不可以
                  a.數據:不可變(常量)public static final int a; static是在類加載是執行,是不可變的。
                  b. public abstract String draw();


             6.抽象和接口的比較
                  a.抽象一定有構造方法,接口沒有構造方法
                  b.抽象不可以實現多繼承,接口可以
                  c.抽象可以繼承接口;接口不能繼承抽象
     
             7.抽象與接口的應用區別
                  a.涉及資源的引用與加載時候一定運用抽象。接口不能完成的時候考慮用抽象

             8.多態特性:通過同一種相同功能單元,不同的實現細節
                  a.編譯時多態性:重載{方法名相同、參數個數相同類型不同、返回不區分}
                  b.運行時多態性:重寫 {子類的訪問權限不能比父類的訪問權限小}、反射機制
      

    posted @ 2010-09-07 18:28 飛龍劍 閱讀(266) | 評論 (1)編輯 收藏
    心情隨筆

    這段時間都在忙著做學生選課系統,初次接觸jquery以及ajax這樣的東西,還有點透過來。
        項目起初,老師只給了我們一個DWZ富框架,讓我們下去仔細的琢磨其中的知識運用,然后仿照運用在選課系統上面。在接到這樣的一個前臺頁面框架,我們花了基本上一周的時間來研究這個,最后得出了一些知識結論。這個框架雖然好用,但是對于一個沒有接觸過JQUERY、AJAX的來說還是有一定的難度的。
        上周我們完成了學生選課系統管理員操作基礎信息管理模塊,這周我們還要對教師選課模塊進行策劃設計完成相應的功能實現,所以說還是比較累的。想起那幾天老師又不給我們講,他天天就往公司跑,完全沒有管我們,只曉得把項目丟給我們,到時提交驗收。我們沒辦法也得天天上百度查資料呀,有時候為了解決一點點小小的技術問題,一連百度了半天,而且有時候還沒有得到答案,你說郁悶不嘛,哎!為啥這樣的苦喲,這行還真考驗人的耐力和毅力,當然我覺得學這行就是考你的自學能力,自學能力要求高,這個行業的技術的在飛速的發展,不斷變更,沒有好的學習能力是不行的。在各個大型公司的招聘會上,對應聘者的學習能力排在第一位,要求你的學習能力要高。
        今天我們院有個招聘會,好像是浙江稅務公司重慶分公司招系統維護人員。去應聘的人說他們都是考你的基礎,一些計算機方面的基礎。

    posted @ 2010-08-31 23:24 飛龍劍 閱讀(1046) | 評論 (1)編輯 收藏
    主站蜘蛛池模板: 国产精品高清视亚洲精品| 亚洲AV无码乱码在线观看富二代 | 污污免费在线观看| 成年在线网站免费观看无广告| 精品亚洲国产成人| 国产免费看JIZZ视频| 亚洲日本乱码卡2卡3卡新区| 国产在线观看免费观看不卡| 亚洲乱码一二三四区麻豆| 国产成人无码免费看视频软件 | 亚洲av无码专区在线电影| 噜噜嘿在线视频免费观看| 亚洲精品乱码久久久久久蜜桃图片 | 亚洲高清中文字幕免费| 国产精品亚洲精品| 大学生一级特黄的免费大片视频| xxx毛茸茸的亚洲| 日韩a级毛片免费视频| 一个人看的免费视频www在线高清动漫 | 97av免费视频| 亚洲色无码国产精品网站可下载| 日韩人妻无码免费视频一区二区三区| 亚洲精品亚洲人成在线| 亚洲精品97久久中文字幕无码| aa级毛片毛片免费观看久| 亚洲欧洲日韩不卡| 国产成人免费高清激情视频| 国产亚洲福利精品一区二区| 亚洲欧洲日产国码av系列天堂| 亚洲人成免费网站| 成年女人看片免费视频播放器| 亚洲精品无码久久久久YW| 免费一级大黄特色大片| 暖暖在线视频免费视频| 亚洲91精品麻豆国产系列在线| 亚洲精品tv久久久久久久久久| 99视频在线精品免费| 自拍偷自拍亚洲精品偷一| 国产亚洲成av人片在线观看| 免费精品国产日韩热久久| 亚洲阿v天堂在线2017免费|