小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

華為面試題-JAVA

 昵稱22369024 2015-05-02

,JAVA方面

面向?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)行處理。

說(shuō)出一些常用的類,包,接口,請(qǐng)各舉5個(gè)

類:Math  String  StringBuffer

包:java.lang java.uilt,java.net,java.io,java.awt

接口:collection ,set,list,map,runable

說(shuō)出ArrayList,Vector, LinkedList的存儲(chǔ)性能和特性

ArrayListVector都是使用數(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ù)的有用的方法。 
 
response response表示HttpServletResponse對(duì)象,并提供了幾個(gè)用于設(shè)置送回 瀏覽器的響應(yīng)的方法(如cookies,頭信息等) 

out out 對(duì)象是javax.jsp.JspWriter的一個(gè)實(shí)例,并提供了幾個(gè)方法使你能用于向?yàn)g覽器回送輸出結(jié)果。 

pageContext pageContext表示一個(gè)javax.servlet.jsp.PageContext對(duì)象。它是用于方便存取各種范圍的名字空間、servlet相關(guān)的對(duì)象的API,并且包裝了通用的servlet相關(guān)功能的方法。 

session session表示一個(gè)請(qǐng)求的javax.servlet.http.HttpSession對(duì)象。Session可以存貯用戶的狀態(tài)信息 

application applicaton 表示一個(gè)javax.servle.ServletContext對(duì)象。這有助于查找有關(guān)servlet引擎和servlet環(huán)境的信息 

config config表示一個(gè)javax.servlet.ServletConfig對(duì)象。該對(duì)象用于存取servlet實(shí)例的初始化參數(shù)。 

page page表示從該頁(yè)面產(chǎn)生的一個(gè)servlet實(shí)例

 

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.java

import 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.java

import 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ō)出ServletCGI的區(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ō)出SessionBeanEntityBean的區(qū)別,StatefulBeanStatelessBean的區(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ì)象。

 

實(shí)體bean

會(huì)話bean

持久對(duì)象,允許保存記錄的信息

不是持久的,允許保存客戶端的狀態(tài)信息

有一個(gè)主鍵,可以搜索到

不可以被搜索

可以被共享

通常一個(gè)用戶使用一個(gè)bean

必須被顯示刪除

過(guò)一段非活動(dòng)期后將被自動(dòng)回收

不受服務(wù)器宕機(jī)影響

受服務(wù)器宕機(jī)影響

刪除意味著底層數(shù)據(jù)庫(kù)記錄被刪除

刪除意味著從容器中刪除,不能再使用,并且其狀態(tài)信息也將丟失

 

13EJB包括(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ā)一次。

 

 


    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多