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