,JAVA方面 1 面向?qū)ο蟮奶卣饔心男┓矫?/font> 封裝 繼承 多態(tài) 2 String是最基本的數(shù)據(jù)類型嗎? 不是 3 int 和 Integer 有什么區(qū)別 int 是基本數(shù)據(jù)類型 Integer 是int的包裝類 4 String 和StringBuffer的區(qū)別 String創(chuàng)建的對象的內(nèi)容不能改變 StringBuffer創(chuàng)建的對象的內(nèi)容可以改變,是在構造字符串中的一種過度形式,構件字符串各種數(shù)據(jù)類型的可擴充的緩沖區(qū)。 5運行時異常與一般異常有何異同? 異常表示程序運行過程中可能出現(xiàn)的非正常狀態(tài),運行時異常表示虛擬機的通常操作中可能遇到的異常,是一種常見運行錯誤。java編譯器要求方法必須聲明拋出可能發(fā)生的非運行時異常,但是并不要求必須聲明拋出未被捕獲的運行時異常。
運行異常是指因設計或?qū)崿F(xiàn)方式不當導致的問題??梢哉f是程序員原因?qū)е碌模緛?/span>可以避免發(fā)生的情況 一般的異常是描述運行時遇到的困難,它通常是由環(huán)境而非程序員的原因引起的,可以進行處理。 6 說出一些常用的類,包,接口,請各舉5個 類:Math String StringBuffer 包:java.lang java.uilt,java.net,java.io,java.awt 接口:collection ,set,list,map,runable 7 說出ArrayList,Vector, LinkedList的存儲性能和特性 ArrayList和Vector都是使用數(shù)組方式存儲數(shù)據(jù),此數(shù)組元素數(shù)大于實際存儲的數(shù)據(jù)以便增加和插入元素,它們都允許直接按序號索引元素,但是插入元素要涉及數(shù)組元素移動等內(nèi)存操作,所以索引數(shù)據(jù)快而插入數(shù)據(jù)慢,Vector由于使用了synchronized方法(線程安全),通常性能上較ArrayList差,而LinkedList使用雙向鏈表實現(xiàn)存儲,按序號索引數(shù)據(jù)需要進行前向或后向遍歷,但是插入數(shù)據(jù)時只需要記錄本項的前后項即可,所以插入速度較快。 8設計4個線程,其中兩個線程每次對j增加1,另外兩個線程對j每次減少1。寫出程序。 以下程序使用內(nèi)部類實現(xiàn)線程,對j增減的時候沒有考慮順序問題。 public class ThreadTest1{ private int j; public static void main(String args[]){ ThreadTest1 tt=new ThreadTest1(); Inc inc=tt.new Inc(); Dec dec=tt.new Dec(); for(int i=0;i<2;i++){ Thread t=new Thread(inc); t.start(); t=new Thread(dec); t.start(); } } private synchronized void inc(){ j++; System.out.println(Thread.currentThread().getName()+"-inc:"+j); } private synchronized void dec(){ j--; System.out.println(Thread.currentThread().getName()+"-dec:"+j); } class Inc implements Runnable{ public void run(){ for(int i=0;i<100;i++){ inc(); } } } class Dec implements Runnable{ public void run(){ for(int i=0;i<100;i++){ dec(); } } } } 9. JSP的內(nèi)置對象及方法。 request request表示HttpServletRequest對象。它包含了有關瀏覽器請求的信息,并且提供了幾個用于獲取cookie, header, 和session數(shù)據(jù)的有用的方法。
request:客戶端請求,包括GET/POST請求傳遞過來的參數(shù)
response:網(wǎng)頁傳回客戶端的反應
pagecontext:管理網(wǎng)頁屬性
session:與請求相關的會話
application:腳本程序的運行環(huán)境
out:傳送響應的輸出流
config:腳本程序的配置對象
exception:處理異常和錯誤
page:JSP 網(wǎng)頁本身
10.用socket通訊寫出客戶端和服務器端的通訊,要求客戶發(fā)送數(shù)據(jù)后能夠回顯相同的數(shù)據(jù)。
TestServer.javaimport java.net.*; import java.io.*;
public class TestServer { public static void main(String args[]) { try { ServerSocket s = new ServerSocket(8888); while (true) { Socket s1 = s.accept(); InputStream is = s1.getInputStream(); DataInputStream dis = new DataInputStream(is); OutputStream os = s1.getOutputStream(); DataOutputStream dos = new DataOutputStream(os); dos.writeUTF(dis.readUTF()); dis.close(); dos.close(); s1.close(); } }catch (IOException e) { System.out.println("程序運行出錯:" + e); } } } TestClient.javaimport java.net.*; import java.io.*; public class TestClient { public static void main(String args[]) { try { Socket s1 = new Socket("127.0.0.1", 8888); OutputStream os = s1.getOutputStream(); DataOutputStream dos = new DataOutputStream(os); dos.writeUTF("i love you!!!"); InputStream is = s1.getInputStream(); DataInputStream dis = new DataInputStream(is); System.out.println(dis.readUTF()); dos.close(); dis.close(); s1.close(); } catch (ConnectException connExc) { System.err.println("服務器連接失??!"); } catch (IOException e) { } } } 11說出Servlet的生命周期,并說出Servlet和CGI的區(qū)別。 Servlet被服務器實例化后,容器運行其init方法,請求到達時運行其service方法,service方法自動派遣運行與請求對應的doXXX方法(doGet,doPost)等,當服務器決定將實例銷毀的時候調(diào)用其destroy方法。 與cgi的區(qū)別在于servlet處于服務器進程中,它通過多線程方式運行其service方法,一個實例可以服務于多個請求,并且其實例一般不會銷毀,而CGI對每個請求都產(chǎn)生新的進程,服務完成后就銷毀,所以效率上低于servlet。 12.EJB是基于哪些技術實現(xiàn)的?并說出SessionBean和EntityBean的區(qū)別,StatefulBean和StatelessBean的區(qū)別。 EJB是基于對象組件模型的,低層的事務服務用了API技術 會話bean是一種作為單用戶執(zhí)行的對象 實體bean是用來對包含在企業(yè)系統(tǒng)中的數(shù)據(jù)進行封裝的EJB,是對數(shù)據(jù)庫中的數(shù)據(jù)提供了一種對象的映射,它是用來代表底層的對象。
13.EJB包括(SessionBean,EntityBean)說出他們的生命周期,及如何管理事務的?
14.說出數(shù)據(jù)連接池的工作機制是什么?
15同步和異步有和異同,在什么情況下分別使用他們?舉例說明。
16應用服務器有那些?
17你所知道的集合類都有哪些?主要方法?
18給你一個:驅(qū)動程序A,數(shù)據(jù)源名稱為B,用戶名稱為C,密碼為D,數(shù)據(jù)庫表為T,請用JDBC檢索出表T的所有數(shù)據(jù)。 19.說出在JSP頁面里是怎么分頁的? 頁面需要保存以下參數(shù): 總行數(shù):根據(jù)sql語句得到總行數(shù) 每頁顯示行數(shù):設定值 當前頁數(shù):請求參數(shù) 頁面根據(jù)當前頁數(shù)和每頁行數(shù)計算出當前頁第一行行數(shù),定位結果集到此行,對結果集取出每頁顯示行數(shù)的行即可。
數(shù)據(jù)庫方面:
1. 存儲過程和函數(shù)的區(qū)別 存儲過程是用戶定義的一系列sql語句的集合,涉及特定表或其它對象的任務,用戶可以調(diào)用存儲過程,而函數(shù)通常是數(shù)據(jù)庫已定義的方法,它接收參數(shù)并返回某種類型的值并且不涉及特定用戶表。 2. 事務是什么? 事務是作為一個邏輯單元執(zhí)行的一系列操作,一個邏輯工作單元必須有四個屬性,稱為 ACID(原子性、一致性、隔離性和持久性)屬性,只有這樣才能成為一個事務: 原子性 事務必須是原子工作單元;對于其數(shù)據(jù)修改,要么全都執(zhí)行,要么全都不執(zhí)行。 一致性 事務在完成時,必須使所有的數(shù)據(jù)都保持一致狀態(tài)。在相關數(shù)據(jù)庫中,所有規(guī)則都必須應用于事務的修改,以保持所有數(shù)據(jù)的完整性。事務結束時,所有的內(nèi)部數(shù)據(jù)結構(如 B 樹索引或雙向鏈表)都必須是正確的。 隔離性 由并發(fā)事務所作的修改必須與任何其它并發(fā)事務所作的修改隔離。事務查看數(shù)據(jù)時數(shù)據(jù)所處的狀態(tài),要么是另一并發(fā)事務修改它之前的狀態(tài),要么是另一事務修改它之后的狀態(tài),事務不會查看中間狀態(tài)的數(shù)據(jù)。這稱為可串行性,因為它能夠重新裝載起始數(shù)據(jù),并且重播一系列事務,以使數(shù)據(jù)結束時的狀態(tài)與原始事務執(zhí)行的狀態(tài)相同。 持久性 事務完成之后,它對于系統(tǒng)的影響是永久性的。該修改即使出現(xiàn)系統(tǒng)故障也將一直保持。
3. 游標的作用?如何知道游標已經(jīng)到了最后? 游標用于定位結果集的行,通過判斷全局變量@@FETCH_STATUS可以判斷是否到了最后,通常此變量不等于0表示出錯或到了最后。 4. 觸發(fā)器分為事前觸發(fā)和事后觸發(fā),這兩種觸發(fā)有和區(qū)別。語句級觸發(fā)和行級觸發(fā)有何區(qū)別。 事前觸發(fā)器運行于觸發(fā)事件發(fā)生之前,而事后觸發(fā)器運行于觸發(fā)事件發(fā)生之后。通常事前觸發(fā)器可以獲取事件之前和新的字段值。 語句級觸發(fā)器可以在語句執(zhí)行前或后執(zhí)行,而行級觸發(fā)在觸發(fā)器所影響的每一行觸發(fā)一次。
|
|
來自: 昵稱22369024 > 《IT技術》