javaGrowing

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            92 隨筆 :: 33 文章 :: 49 評論 :: 0 Trackbacks

          線程編程方面   

          60java中有幾種方法可以實現(xiàn)一個線程?用什么關鍵字修飾同步方法? stop()suspend()法為何不推薦使用?
          答:有兩種實現(xiàn)方法,分別是繼承Thread類與實現(xiàn)Runnable接口
          用synchronized關鍵字修飾同步方法
          反對使用stop(),是因為它不安全。它會解除由線程獲取的所有鎖定,而且如果對象處于一種不連貫狀態(tài),那么其他線程能在那種狀態(tài)下檢查和修改它們。結果很難檢查出真正的問題所在。suspend()方法容易發(fā)生死鎖。調用suspend()的時候,目標線程會停下來,但卻仍然持有在這之前獲得的鎖定。此時,其他任何線程都不能訪問鎖定的資源,除非被"掛起"的線程恢復運行。對任何線程來說,如果它們想恢復目標線程,同時又試圖使用任何一個鎖定的資源,就會造成死鎖。所以不應該使用suspend(),而應在自己的Thread類中置入一個標志,指出線程應該活動還是掛起。若標志指出線程應該掛起,便用wait()命其進入等待狀態(tài)。若標志指出線程應當恢復,則用一個notify()重新啟動線程。

          61sleep()  wait() 有什么區(qū)別
          答:
          sleep是線程類(Thread)的方法,導致此線程暫停執(zhí)行指定時間,給執(zhí)行機會給其他線程,但是監(jiān)控狀態(tài)依然保持,到時后會自動恢復。調用sleep不會釋放對象鎖。
          wait是Object類的方法,對此對象調用wait方法導致本線程放棄對象鎖,進入等待此對象的等待鎖定池,只有針對此對象發(fā)出notify方法(或notifyAll)后本線程才進入對象鎖定池準備獲得對象鎖進入運行狀態(tài)。

          62
          、同步和異步有何異同,在什么情況下分別使用他們?舉例說明。
          答:
          如果數(shù)據(jù)將在線程間共享。例如正在寫的數(shù)據(jù)以后可能被另一個線程讀到,或者正在讀的數(shù)據(jù)可能已經被另一個線程寫過了,那么這些數(shù)據(jù)就是共享數(shù)據(jù),必須進行同步存取。
          當應用程序在對象上調用了一個需要花費很長時間來執(zhí)行的方法,并且不希望讓程序等待方法的返回時,就應該使用異步編程,在很多情況下采用異步途徑往往更有效率。
          63、啟動一個線程是用run()還是start()?
          答:啟動一個線程是調用start()方法,使線程所代表的虛擬處理機處于可運行狀態(tài),這意味著它可以由JVM調度并執(zhí)行。這并不意味著線程就會立即運行。run()方法可以產生必須退出的標志來停止一個線程。 

          64
          、當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法?
          答:不能,一個對象的一個synchronized方法只能由一個線程訪問。

          65
          、請說出你所知道的線程同步的方法。
          答:
          wait():使一個線程處于等待狀態(tài),并且釋放所持有的對象的lock。
          sleep():使一個正在運行的線程處于睡眠狀態(tài),是一個靜態(tài)方法,調用此方法要捕捉InterruptedException異常。
          notify():喚醒一個處于等待狀態(tài)的線程,注意的是在調用此方法的時候,并不能確切的喚醒某一個等待狀態(tài)的線程,而是由JVM確定喚醒哪個線程,而且不是按優(yōu)先級。
          Allnotity():喚醒所有處入等待狀態(tài)的線程,注意并不是給所有喚醒線程一個對象的鎖,而是讓它們競爭。
          66、多線程有幾種實現(xiàn)方法,都是什么?同步有幾種實現(xiàn)方法,都是什么

          答:
          多線程有兩種實現(xiàn)方法,分別是繼承Thread類與實現(xiàn)Runnable接口 
          同步的實現(xiàn)方面有兩種,分別是synchronized,wait與notify
          67、線程的基本概念、線程的基本狀態(tài)以及狀態(tài)之間的關系
          答:線程指在程序執(zhí)行過程中,能夠執(zhí)行程序代碼的一個執(zhí)行單位,每個程序至少都有一個線程,也就是程序本身。
          Java中的線程有四種狀態(tài)分別是:運行、就緒、掛起、結束
          68、簡述synchronizedjava.util.concurrent.locks.Lock的異同 

          答:主要相同點:Lock能完成synchronized所實現(xiàn)的所有功能
          主要不同點:Lock有比synchronized更精確的線程語義和更好的性能。synchronized會自動釋放鎖,而Lock一定要求程序員手工釋放,并且必須在finally從句中釋放。

          Jsp方面

          69forward redirect的區(qū)別
          答:forward是服務器請求資源,服務器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,然后把這些內容再發(fā)給瀏覽器,瀏覽器根本不知道服務器發(fā)送的內容是從哪兒來的,所以它的地址欄中還是原來的地址。
              redirect就是服務端根據(jù)邏輯,發(fā)送一個狀態(tài)碼,告訴瀏覽器重新去請求那個地址,一般來說瀏覽器會用剛才請求的所有參數(shù)重新請求,所以session,request參數(shù)都可以獲取。
          70jsp有哪些內置對象?作用分別是什么?

          答:JSP共有以下9種基本內置組件(可與ASP6種內部組件相對應):
           request 用戶端請求,此請求會包含來自GET/POST請求的參數(shù)

             response
          網頁傳回用戶端的回應

             pageContext
          網頁的屬性是在這里管理

             session
          與請求有關的會話期

             application servlet
          正在執(zhí)行的內容

             out
          用來傳送回應的輸出

             config servlet
          的構架部件
             page JSP
          網頁本身

             exception
          針對錯誤網頁,未捕捉的例外

          71
          jsp有哪些動作?作用分別是什么?
          :JSP共有以下6種基本動作
             jsp:include
          :在頁面被請求的時候引入一個文件。
             jsp:useBean
          :尋找或者實例化一個JavaBean

             jsp:setProperty
          :設置JavaBean的屬性。

             jsp:getProperty
          :輸出某個JavaBean的屬性。

             jsp:forward
          :把請求轉到一個新的頁面。

             jsp:plugin
          :根據(jù)瀏覽器類型為Java插件生成OBJECTEMBED標記

          72
          JSP中動態(tài)INCLUDE與靜態(tài)INCLUDE的區(qū)別?
          答:動態(tài)INCLUDEjsp:include動作實現(xiàn)
             <jsp:include page="included.jsp" flush="true" />
          它總是會檢查所含文件中的變化,適合用于包含動態(tài)頁面,并且可以帶參數(shù)
            
          靜態(tài)INCLUDEinclude偽碼實現(xiàn),定不會檢查所含文件的變化,適用于包含靜態(tài)頁面
             <%@ include file="included.htm" %>
          73
          、兩種跳轉方式分別是什么?有什么區(qū)別?
          答:有兩種,分別為:
            <jsp:include page="included.jsp" flush="true">
            <jsp:forward page= "nextpage.jsp"/>
          前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是原來的頁面。執(zhí)行完后還會回來,相當于函數(shù)調用。并且可以帶參數(shù).后者完全轉向新頁面,不會再回來。相當于go to 語句。
          74
          JSP的內置對象及方法。
          答:request表示HttpServletRequest對象。它包含了有關瀏覽器請求的信息,并且提供了幾個用于獲取cookie, header, session數(shù)據(jù)的有用的方法。 
              response
          表示HttpServletResponse對象,并提供了幾個用于設置送回 瀏覽器的響應的方法(如cookies,頭信息等)
           
              out
          對象是javax.jsp.JspWriter的一個實例,并提供了幾個方法使你能用于向瀏覽器回送輸出結果。
           
              pageContext
          表示一個javax.servlet.jsp.PageContext對象。它是用于方便存取各種范圍的名字空間、servlet相關的對象的API,并且包裝了通用的servlet相關功能的方法。
           
              session
          表示一個請求的javax.servlet.http.HttpSession對象。Session可以存貯用戶的狀態(tài)信息
           
              applicaton 
          表示一個javax.servle.ServletContext對象。這有助于查找有關servlet引擎和servlet環(huán)境的信息
           
              config
          表示一個javax.servlet.ServletConfig對象。該對象用于存取servlet實例的初始化參數(shù)。
           
              page
          表示從該頁面產生的一個servlet實例

          Servlet方面

          75、說一說Servlet的生命周期?
          :servlet有良好的生存期的定義,包括加載和實例化、初始化、處理請求以及服務結束。這個生存期由javax.servlet.Servlet接口的init,servicedestroy方法表達。 Servlet被服務器實例化后,容器運行其init方法,請求到達時運行其service方法,service方法自動派遣運行與請求對應的doXXX方法(doGetdoPost)等,當服務器決定將實例銷毀的時候調用其destroy方法。
          cgi的區(qū)別在于servlet處于服務器進程中,它通過多線程方式運行其service方法,一個實例可以服務于多個請求,并且其實例一般不會銷毀,而CGI對每個請求都產生新的進程,服務完成后就銷毀,所以效率上低于servlet
          76JAVA SERVLET APIforward() redirect()的區(qū)別?
          :前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向后的地址;后者則是完全的跳轉,瀏覽器將會得到跳轉的地址,并重新發(fā)送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉后的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,盡量使用forward()方法,并且,這樣也有助于隱藏實際的鏈接。在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用sendRedirect()方法。
          77
          Servlet的基本架構
          答:
          public class ServletName extends HttpServlet {
            public void doPost(HttpServletRequest request, HttpServletResponse response) throws
                ServletException, IOException  {
                }
            public void doGet(HttpServletRequest request, HttpServletResponse response) throws
                ServletException, IOException  {
                }
          }

          78、什么情況下調用doGet()doPost()
          答:Jsp頁面中的form標簽里的method屬性為get時調用doGet(),為post時調用doPost()
          79servlet的生命周期
          答:web容器加載servlet,生命周期開始。通過調用servletinit()方法進行servlet的初始化。通過調用service()方法實現(xiàn),根據(jù)請求的不同調用不同的do***()方法。結束服務,web容器調用servletdestroy()方法。
          80、如何現(xiàn)實servlet的單線程模式
          答:<%@ page isThreadSafe="false"%>
          81、頁面間對象傳遞的方法

          答:requestsessionapplicationcookie
          82JSPServlet有哪些相同點和不同點,他們之間的聯(lián)系是什么? 
          答:JSPServlet技術的擴展,本質上是Servlet的簡易方式,更強調應用的外表表達。JSP編譯后是"servlet"ServletJSP最主要的不同點在于,Servlet的應用邏輯是在Java文件中,并且完全從表示層中的HTML里分離開來。而JSP的情況是JavaHTML可以組合成一個擴展名為.jsp的文件。JSP側重于視圖,Servlet主要用于控制邏輯。

          83、四種會話跟蹤技術
          答:會話作用域ServletsJSP 頁面描述
          page
          否是代表與一個頁面相關的對象和屬性。一個頁面由一個編譯好的 Java servlet 類(可以帶有任何的 include 指令,但是沒有 include 動作)表示。這既包括 servlet 又包括被編譯成 servlet  JSP 頁面
          request
          是是代表與 Web 客戶機發(fā)出的一個請求相關的對象和屬性。一個請求可能跨越多個頁面,涉及多個 Web 組件(由于 forward 指令和 include 動作的關系)
          session
          是是代表與用于某個 Web 客戶機的一個用戶體驗相關的對象和屬性。一個 Web 會話可以也經常會跨越多個客戶機請求
          application
          是是代表與整個 Web 應用程序相關的對象和屬性。這實質上是跨越整個 Web 應用程序,包括多個頁面、請求和會話的一個全局作用域
          84Request對象的主要方法
          答:
          setAttribute(String name,Object):設置名字為namerequest的參數(shù)值
          getAttribute(String name)
          :返回由name指定的屬性值
          getAttributeNames()
          :返回request對象所有屬性的名字集合,結果是一個枚舉的實例
          getCookies()
          :返回客戶端的所有Cookie對象,結果是一個Cookie數(shù)組
          getCharacterEncoding()
          :返回請求中的字符編碼方式
          getContentLength()
          :返回請求的Body的長度
          getHeader(String name)
          :獲得HTTP協(xié)議定義的文件頭信息
          getHeaders(String name)
          :返回指定名字的request Header的所有值,結果是一個枚舉的實例
          getHeaderNames()
          :返回所以request Header的名字,結果是一個枚舉的實例
          getInputStream()
          :返回請求的輸入流,用于獲得請求中的數(shù)據(jù)
          getMethod()
          :獲得客戶端向服務器端傳送數(shù)據(jù)的方法
          getParameter(String name)
          :獲得客戶端傳送給服務器端的有name指定的參數(shù)值
          getParameterNames()
          :獲得客戶端傳送給服務器端的所有參數(shù)的名字,結果是一個枚舉的實例
          getParameterValues(String name)
          :獲得有name指定的參數(shù)的所有值
          getProtocol()
          :獲取客戶端向服務器端傳送數(shù)據(jù)所依據(jù)的協(xié)議名稱
          getQueryString()
          :獲得查詢字符串
          getRequestURI()
          :獲取發(fā)出請求字符串的客戶端地址
          getRemoteAddr()
          :獲取客戶端的IP地址
          getRemoteHost()
          :獲取客戶端的名字
          getSession([Boolean create])
          :返回和請求相關Session
          getServerName()
          :獲取服務器的名字

          getServletPath()
          :獲取客戶端所請求的腳本文件的路徑
          getServerPort()
          :獲取服務器的端口號
          removeAttribute(String name)
          :刪除請求中的一個屬性
          85、我們在web應用開發(fā)過程中經常遇到輸出某種編碼的字符,如iso8859-1等,如何輸出個某種編碼的字符串?
          答:

            Public String translate (String str) {
              String tempStr = "";
              try {
                tempStr = new String(str.getBytes("ISO-8859-1"), "GBK");
                tempStr = tempStr.trim();
              }
              catch (Exception e) {
                System.err.println(e.getMessage());
              }
              return tempStr;
            }
          86Servlet執(zhí)行時一般實現(xiàn)哪幾個方法?

          答:
          public void init(ServletConfig config)
          public ServletConfig getServletConfig()
          public String getServletInfo()
          public void service(ServletRequest request,ServletResponse response)
          public void destroy()

          JdbcJdo方面

          87Class.forName的作用?為什么要用?
          答:調用該訪問返回一個以字符串指定類名的類的對象。
          88
          Jdo是什么?
          答:JDOJava對象持久化的新的規(guī)范,為java data object的簡稱,也是一個用于存取某種數(shù)據(jù)倉庫中的對象的標準化APIJDO提供了透明的對象存儲,因此對開發(fā)人員來說,存儲數(shù)據(jù)對象完全不需要額外的代碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發(fā)人員解脫出來,從而集中時間和精力在業(yè)務邏輯上。另外,JDO很靈活,因為它可以在任何數(shù)據(jù)底層上運行。JDBC只是面向關系數(shù)據(jù)庫(RDBMS)JDO更通用,提供到任何數(shù)據(jù)底層的存儲功能,比如關系數(shù)據(jù)庫、文件、XML以及對象數(shù)據(jù)庫(ODBMS)等等,使得應用可移植性更強。
          89、說出數(shù)據(jù)連接池的工作機制是什么?
          答:J2EE
          服務器啟動時會建立一定數(shù)量的池連接,并一直維持不少于此數(shù)目的池連接。客戶端程序需要連接時,池驅動程序會返回一個未使用的池連接并將其表記為忙。如果當前沒有空閑連接,池驅動程序就新建一定數(shù)量的連接,新建連接的數(shù)量有配置參數(shù)決定。當使用的池連接調用完成后,池驅動程序將此連接表記為空閑,其他調用就可以使用這個連接。
          90Jdo是什么
          答:JDOJava對象持久化的新的規(guī)范,為java data object的簡稱,也是一個用于存取某種數(shù)據(jù)倉庫中的對象的標準化APIJDO提供了透明的對象存儲,因此對開發(fā)人員來說,存儲數(shù)據(jù)對象完全不需要額外的代碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發(fā)人員解脫出來,從而集中時間和精力在業(yè)務邏輯上。另外,JDO很靈活,因為它可以在任何數(shù)據(jù)底層上運行。JDBC只是面向關系數(shù)據(jù)庫(RDBMSJDO更通用,提供到任何數(shù)據(jù)底層的存儲功能,比如關系數(shù)據(jù)庫、文件、XML以及對象數(shù)據(jù)庫(ODBMS)等等,使得應用可移植性更強。

          Xml方面

          91xml有哪些解析技術?區(qū)別是什么?
          答:DOM,SAX,STAX
          DOM:
          處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構占用的內存較多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問SAX:不現(xiàn)于DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。當遇到像文件開頭,文檔結束,或者標簽開頭與標簽結束時,它會觸發(fā)一個事件,用戶通過在其回調事件中寫入處理代碼來處理XML文件,適合對XML的順序訪問
          STAX:Streaming API for XML (StAX)
          92
          、你在項目中用到了xml技術的哪些方面?如何實現(xiàn)的?
          答:用到了數(shù)據(jù)存貯,信息配置兩方面。在做數(shù)據(jù)交換平臺時,將不能數(shù)據(jù)源的數(shù)據(jù)組裝成XML文件,然后將XML文件壓縮打包加密后通過網絡傳送給接收者,接收解密與解壓縮后再同XML文件中還原相關信息進行處理。在做軟件配置時,利用XML可以很方便的進行,軟件的各種配置參數(shù)都存貯在XML文件中。
          93
          XML文檔定義有幾種形式?它們之間有何本質區(qū)別?解析XML文檔有哪幾種方式? 
          答:a: 兩種形式 dtd  schemab: 本質區(qū)別:schema本身是xml的,可以被XML解析器解析(這也是從DTD上發(fā)展schema的根本目的)c:DOM,SAX,STAX
           
              DOM:
          處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構占用的內存較多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問

          SAX:
          不現(xiàn)于DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。當遇到像文件開頭,文檔結束,或者標簽開頭與標簽結束時,它會觸發(fā)一個事件,用戶通過在其回調事件中寫入處理代碼來處理XML文件,適合對XML的順序訪問 
          STAX:Streaming API for XML (StAX)

          posted on 2006-02-28 11:11 javaGrowing 閱讀(1937) 評論(0)  編輯  收藏 所屬分類: java面試試題
          主站蜘蛛池模板: 阿图什市| 西和县| 扎兰屯市| 东乌| 永顺县| 江北区| 轮台县| 罗平县| 平泉县| 建宁县| 桃江县| 洪雅县| 应用必备| 杭州市| 利辛县| 溆浦县| 望城县| 商河县| 鄂州市| 凤台县| 怀柔区| 会宁县| 通城县| 宣城市| 南京市| 翁牛特旗| 兰州市| 三都| 宁化县| 鄂托克旗| 合阳县| 滨海县| 庆阳市| 夏邑县| 台州市| 长沙县| 比如县| 石嘴山市| 鄂托克前旗| 景宁| 敦煌市|