JAVA面試題
1照皆、作用域public,private,protected,以及不寫時的區(qū)別
答:區(qū)別如下:
作用域 當前類 同一package 子孫類 其他 package
public √ √ √ √
protected √ √ √ ×
friendly √ √ × ×
private √ × × ×
2、不寫時默認為friendly2银酗、 Anonymous Inner Class (匿名內(nèi)部類) 是否可以extends(繼承)其它類,
是否可以implements(實現(xiàn))interface(接口)
答:匿名的內(nèi)部類是沒有名字的內(nèi)部類。不能extends(繼承) 其它類黍特,但一個內(nèi)部類可以作
為一個接口蛙讥,由另一個內(nèi)部類實現(xiàn)
3、Static Nested Class 和 Inner Class的不同
答:Nested Class (一般是C++的說法)衅澈,Inner Class (一般是JAVA的說法)键菱。Java內(nèi)部類與C++
嵌套類最大的不同就在于是否有指向外部的引用上。注: 靜態(tài)內(nèi)部類(Inner Class)意味著1創(chuàng)建一個static內(nèi)部類的對象今布,不需要一個外部類對象经备,2 不能從一個static內(nèi)部類的一個對象訪問一個外部類對象
4、&和&&的區(qū)別
答:&是位運算符部默,表示按位與運算侵蒙,&&是邏輯運算符,表示邏輯與(and)
5傅蹂、Collection 和 Collections的區(qū)別
答:Collection是集合類的上級接口纷闺,繼承與他的接口主要有 Set 和List.
Collections是針對集合類的一個幫助類,他提供一系列靜態(tài)方法實現(xiàn)對各種集合的搜索份蝴、排序犁功、線程安全化等操作
6、什么時候用assert
答: assertion(斷言)在軟件開發(fā)中是一種常用的調(diào)試方式婚夫,很多開發(fā)語言中都支持這種機制浸卦。
在實現(xiàn)中,assertion就是在程序中的一條語句案糙,它對一個 boolean 表達式進行檢查限嫌,一個正確程序必須保證這個boolean表達式的值為 true;如果該值為false时捌,說明程序已經(jīng)處于不正確的狀態(tài)下怒医,系統(tǒng)將給出警告或退出。一般來說奢讨, assertion用于保證程序最基本稚叹、關(guān)鍵的正確性。assertion 檢查通常在開發(fā)和測試時開啟拿诸。為了提高性能入录,在軟件發(fā)布后,assertion檢查通常是關(guān)閉的
7佳镜、String s = new String("xyz");創(chuàng)建了幾個String Object
答:兩個僚稿,一個字符對象,一個字符對象引用對象
8蟀伸、Math.round(11.5)等于多少? Math.round(-11.5)等于多少
答: Math.round(11.5)==12;Math.round(-11.5)==-11;round方法返回與參數(shù)最接近的長整數(shù)蚀同,參數(shù)加1/2 后求其floor
9缅刽、short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯
答:short s1 = 1; s1 = s1 + 1; (s1+1運算結(jié)果是int型,需要強制轉(zhuǎn)換類型)short s1 = 1; s1 += 1;(可以正確編譯)
10蠢络、Java有沒有g(shù)oto
答:java中的保留字衰猛,現(xiàn)在沒有在java中使用
11、數(shù)組有沒有l(wèi)ength()這個方法? String有沒有l(wèi)ength()這個方法
答:數(shù)組沒有l(wèi)ength()這個方法刹孔,有 length的屬性啡省。String有 length()這個方法
12、Overload和Override的區(qū)別髓霞。Overloaded 的方法是否可以改變返回值的類型
答:方法的重寫 Overriding 和重載 Overloading 是 Java 多態(tài)性的不同表現(xiàn)卦睹。重寫 Overriding
是父類與子類之間多態(tài)性的一種表現(xiàn),重載 Overloading 是一個類中多態(tài)性的一種表現(xiàn)方库。如果在子類中定義某方法與其父類有相同的名稱和參數(shù)结序,我們說該方法被重寫 (Overriding)。子類的對象使用這個方法時纵潦,將調(diào)用子類中的定義徐鹤,對它而言,父類中的定義如同被"屏蔽" 了邀层。如果在一個類中定義了多個同名的方法返敬,它們或有不同的參數(shù)個數(shù)或有不同的參數(shù)類型,則稱為方法的重載(Overloading)寥院。Overloaded的方法是可以改變返回值的類型
13劲赠、Set 里的元素是不能重復(fù)的,那么用什么方法來區(qū)分重復(fù)與否呢? 是用==還是 equals()?
它們有何區(qū)別
答:Set里的元素是不能重復(fù)的只磷,那么用iterator()方法來區(qū)分重復(fù)與否经磅。equals()是判讀兩個
Set是否相等 equals()和==方法決定引用值是否指向同一對象 equals()在類中被覆蓋泌绣,為的是當兩個分離
的對象的內(nèi)容和類型相配的話钮追,返回真值
14、給我一個你最常見到的 runtime exception
答 : 常 見 的 運 行 時 異 常 有 如 下 這 些 ArithmeticException, ArrayStoreException,
BufferOverflowException,
BufferUnderflowException, CannotRedoException, CannotUndoException, ClassCastException,
CMMException,
ConcurrentModificationException, DOMException, EmptyStackException,
IllegalArgumentException,
IllegalMonitorStateException, IllegalPathStateException, IllegalStateException,
ImagingOpException,
IndexOutOfBoundsException, MissingResourceException, NegativeArraySizeException,
NoSuchElementException,
NullPointerException, ProfileDataException, ProviderException, RasterFormatException,
SecurityException,
SystemException, UndeclaredThrowableException, UnmodifiableSetException,
UnsupportedOperationException
15阿迈、error和exception有什么區(qū)別
答:error 表示恢復(fù)不是不可能但很困難的情況下的一種嚴重問題元媚。比如說內(nèi)存溢出。不可
能指望程序能處理這樣的情況
exception 表示一種設(shè)計或?qū)崿F(xiàn)問題苗沧。也就是說刊棕,它表示如果程序運行正常,從不會發(fā)生的
情況
16待逞、List, Set, Map是否繼承自 Collection接口
答: List甥角,Set是,Map不是
17识樱、abstract class和interface 有什么區(qū)別
答:聲明方法的存在而不去實現(xiàn)它的類被叫做抽象類(abstract class)嗤无,它用于要創(chuàng)建一個體現(xiàn)某些基本行為的類震束,并為該類聲明方法,但不能在該類中實現(xiàn)該類的情況当犯。不能創(chuàng)建abstract 類的實例垢村。然而可以
創(chuàng)建一個變量,其類型是一個抽象類嚎卫,并讓它指向具體子類的一個實例嘉栓。不能有抽象構(gòu)造函數(shù)或抽象靜態(tài)方法。 Abstract 類的子類為它們父類中的所有抽象方法提供實現(xiàn)拓诸,否則它們也是抽象類為侵佃。取而代之,在子類中實現(xiàn)該方法恰响。知道其行為的其它類可以在類中實現(xiàn)這些方法
接口(interface)是抽象類的變體趣钱。在接口中,所有方法都是抽象的胚宦。多繼承性可通過實現(xiàn)
這樣的接口而獲得首有。接口中的所有方法都是抽象的,沒有一個有程序體枢劝。接口只可以定義 static final成員變量井联。接口的實現(xiàn)與子類相似,除了該實現(xiàn)類不能從接口定義中繼承行為您旁。當類實現(xiàn)特殊接口時烙常,它定義(即將程序體給予)所有這種接口的方法。然后鹤盒,它可以在實現(xiàn)了該接口的類的任何對象上調(diào)用接口的方法蚕脏。由于有抽象類,它允許使用接口名作為引用變量的類型侦锯。通常的動態(tài)聯(lián)編將生效驼鞭。引用可以轉(zhuǎn)換到接口類型或從接口類型轉(zhuǎn)換,instanceof 運算符可以用來決定某對象的類是否實現(xiàn)了接口
18尺碰、 abstract的method 是否可同時是static,是否可同時是 native挣棕,是否可同時是synchronized
答:都不能
19、接口是否可繼承接口? 抽象類是否可實現(xiàn)(implements)接口? 抽象類是否可繼承實體類(concrete class)
答:接口可以繼承接口亲桥。抽象類可以實現(xiàn)(implements)接口洛心,抽象類是否可繼承實體類,但前提是實體類必須有明確的構(gòu)造函數(shù)
20题篷、構(gòu)造器Constructor 是否可被override
答:構(gòu)造器Constructor 不能被繼承词身,因此不能重寫Overriding,但可以被重載Overloading
21番枚、是否可以繼承String類
答:String類是final類故不可以繼承
22法严、try {}里有一個return語句璧瞬,那么緊跟在這個try后的 finally {}里的 code會不會被執(zhí)行,什么時候被執(zhí)行渐夸,在return 前還是后嗤锉?
答:會執(zhí)行,在return前執(zhí)行
23墓塌、用最有效率的方法算出 2乘以8等于幾
答:2 << 3
24瘟忱、兩個對象值相同(x.equals(y) == true),但卻可有不同的 hash code苫幢,這句話對不對
答:不對访诱,有相同的hash code
25、當一個對象被當作參數(shù)傳遞到一個方法后韩肝,此方法可改變這個對象的屬性触菜,并可返回變化后的結(jié)果,那么這里到底是 值傳遞還是引用傳遞
答:是值傳遞哀峻。Java 編程語言只有值傳遞參數(shù)涡相。當一個對象實例作為一個參數(shù)被傳遞到方法中時,參數(shù)的值就是對該對象的引用剩蟀。對象的內(nèi)容可以在被調(diào)用的方法中改變催蝗,但對象的引用是永遠不會改變的
26、swtich是否能作用在byte 上育特,是否能作用在long上丙号,是否能作用在String上
答:witch(expr1)中,expr1 是一個整數(shù)表達式缰冤。因此傳遞給 switch 和 case 語句的參數(shù)應(yīng)該是 int犬缨、 short、 char 或者 byte棉浸。long,string 都不能作用于 swtich
27怀薛、ArrayList 和 Vector 的區(qū)別,HashMap 和Hashtable的區(qū)別
答:就ArrayList與Vector主要從二方面來說.
一.同步性:Vector 是線程安全的,也就是說是同步的涮拗,而 ArrayList 是線程序不安全的乾戏,不是同步的
二.數(shù)據(jù)增長:當需要增長時,Vector默認增長為原來一培迂苛,而 ArrayList卻是原來的一半录豺,就HashMap與 HashTable主要從三方面來說瀑志。
一.歷史原因:Hashtable 是基于陳舊的Dictionary 類的,HashMap是Java 1.2引進的 Map接口
的一個實現(xiàn)
二.同步性:Hashtable 是線程安全的,也就是說是同步的牧挣,而 HashMap 是線程序不安全的,
不是同步的
三.值:只有HashMap可以讓你將空值作為一個表的條目的key或value
28瓷产、char 型變量中能不能存貯一個中文漢字?為什么?
答:是能夠定義成為一個中文的,因為 java中以 unicode 編碼摆出,一個char 占16 個字節(jié),所以放一個中文是沒問題的
29首妖、GC是什么? 為什么要有 GC
答:GC是垃圾收集的意思(Gabage Collection),內(nèi)存處理是編程人員容易出現(xiàn)問題的地方偎漫,忘記或者錯誤的內(nèi)存回收會導(dǎo)致程序或系統(tǒng)的不穩(wěn)定甚至崩潰,Java提供的GC功能可以自動監(jiān)測對象是否超過作用域從而達到自動回收內(nèi)存的目的有缆,Java語言沒有提供釋放已分配內(nèi)存的顯示操作方法象踊。
30、float型float f=3.4是否正確?
答:不正確棚壁。精度不準確,應(yīng)該用強制類型轉(zhuǎn)換杯矩,如下所示:float f=(float)3.4
31、介紹JAVA 中的Collection FrameWork(包括如何寫自己的數(shù)據(jù)結(jié)構(gòu))?
答:Collection FrameWork如下:
Collection
├List
│├LinkedList
│├ArrayList
│└Vector
│ └Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMapCollection 是最基本的集合接口袖外,一個 Collection 代表一組 Object史隆,即Collection的元素(Elements) Map提供key到value的映射
32、抽象類與接口曼验?
答:抽象類與接口都用于抽象泌射,但是抽象類(JAVA中)可以有自己的部分實現(xiàn),而接口則完全是一個標識(同時有多重繼承的功能)鬓照。
JAVA 類實現(xiàn)序例化的方法是實現(xiàn) java.io.Serializable接口
Collection框架中實現(xiàn)比較要實現(xiàn) Comparable 接口和 Comparator 接口
33魄幕、STRING與STRINGBUFFER 的區(qū)別。
答:STRING 的長度是不可變的颖杏,STRINGBUFFER 的長度是可變的纯陨。如果你對字符串中的內(nèi)容
經(jīng)常進行操作,特別是內(nèi)容要修改時留储,那么使用StringBuffer翼抠,如果最后需要String,那么使用StringBuffer的 toString()方法
34获讳、談?wù)刦inal, finally, finalize 的區(qū)別
答:final—修飾符(關(guān)鍵字)如果一個類被聲明為 final阴颖,意味著它不能再派生出新的子類,不能作為父類被繼承丐膝。因此一個類不能既被聲明為 abstract 的量愧,又被聲明為 final 的。將變量或方法聲明為 final帅矗,可以保證它們在使用中不被改變偎肃。
被聲明為 final 的變量必須在聲明時給定初值,而在以后的引用中只能讀取浑此,不可修改累颂。被聲明為final的方法也同樣只能使用,不能重載finally—再異常處理時提供 finally 塊來執(zhí)行任何清除操作。如果拋出一個異常紊馏,那么相匹配的 catch 子句就會執(zhí)行料饥,然后控制就會進入 finally 塊(如果有的話)
finalize—方法名。Java 技術(shù)允許使用 finalize() 方法在垃圾收集器將對象從內(nèi)存中清除出去
之前做必要的清理工作朱监。
這個方法是由垃圾收集器在確定這個對象沒有被引用時對這個對象調(diào)用的岸啡。它是在 Object 類中定義的,因此所有的類都繼承了它赫编。子類覆蓋 finalize() 方法以整理系統(tǒng)資源或者執(zhí)行其他清理工作凰狞。finalize() 方法是在垃圾收集器刪除對象之前對這個對象調(diào)用的
35、面向?qū)ο蟮奶卣饔心男┓矫?br>
答:主要有以下四方面:
1.抽象:
抽象就是忽略一個主題中與當前目標無關(guān)的那些方面沛慢,以便更充分地注意與當前目標有關(guān)的方面赡若。抽象并不打算了解全部問題,而只是選擇其中的一部分团甲,暫時不用部分細節(jié)逾冬。抽象包括兩個方面,一是過程抽象躺苦,
二是數(shù)據(jù)抽象身腻。
2.繼承:
繼承是一種聯(lián)結(jié)類的層次模型,并且允許和鼓勵類的重用匹厘,它提供了一種明確表述共性的方法嘀趟。對象的一個新類可以從現(xiàn)有的類中派生,這個過程稱為類繼承愈诚。新類繼承了原始類的特性她按,新類稱為原始類的派生類(子類),而原始類稱為新類的基類(父類)炕柔。派生類可以從它的基類那里繼承方法和實例變量酌泰,并且類可以修改或增加新的方法使之更適合特殊的需要。
3.封裝:
封裝是把過程和數(shù)據(jù)包圍起來匕累,對數(shù)據(jù)的訪問只能通過已定義的界面陵刹。面向?qū)ο笥嬎闶加谶@個基本概念,即現(xiàn)實世界可以被描繪成一系列完全自治欢嘿、封裝的對象衰琐,這些對象通過一個受保護的接口訪問其他對象。
- 多態(tài)性:
多態(tài)性是指允許不同類的對象對同一消息作出響應(yīng)炼蹦。多態(tài)性包括參數(shù)化多態(tài)性和包含多態(tài)性羡宙。
多態(tài)性語言具有靈活、抽象框弛、行為共享辛辨、代碼共享的優(yōu)勢捕捂,很好的解決了應(yīng)用程序函數(shù)同名問題瑟枫。
36斗搞、String是最基本的數(shù)據(jù)類型嗎
答:基本數(shù)據(jù)類型包括byte、int慷妙、char僻焚、long、float膝擂、double虑啤、boolean和short。
java.lang.String類是final類型的架馋,因此不可以繼承這個類狞山、不能修改這個類。為了提高效率節(jié)省空間叉寂,我們應(yīng)該用 StringBuffer 類
37萍启、int 和 Integer 有什么區(qū)別
答:Java 提供兩種不同的類型:引用類型和原始類型(或內(nèi)置類型)。Int 是 java 的原始數(shù)據(jù)類型屏鳍,Integer是java 為int 提供的封裝類勘纯。Java為每個原始類型提供了封裝類。 原始類型封裝類 ,booleanBoolean,charCharacter,byteByte,shortShort,intInteger,longLong,floatFloat,doubleDouble 引用類型和原始類型的行為完全不同钓瞭,并且它們具有不同的語義驳遵。引用類型和原始類型具有不同的特征和用法,它們包括:大小和速度問題山涡,這種類型以哪種類型的數(shù)據(jù)結(jié)構(gòu)存儲堤结,當引用類型和原始類型用作某個類的實例數(shù)據(jù)時所指定的缺省值。對象引用實例變量的缺省值為 null鸭丛,而原始類型實例變量的缺省值與它們的類型有關(guān)
38霍殴、運行時異常與一般異常有何不同
答:異常表示程序運行過程中可能出現(xiàn)的非正常狀態(tài),運行時異常表示虛擬機的通常操作中
可能遇到的異常系吩,是一種常見運行錯誤来庭。java編譯器要求方法必須聲明拋出可能發(fā)生的非運行時異常,但是并不要求必須聲明拋出未被捕獲的運行時異常穿挨。
39月弛、說出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ù)時只需要記錄本項的前后項即可章母,所以插入速度較快。
40翩剪、HashMap和Hashtable 的區(qū)別
答:HashMap是Hashtable的輕量級實現(xiàn)(非線程安全的實現(xiàn))乳怎,他們都完成了 Map接口,
主要區(qū)別在于HashMap允許空( null)鍵值(key),由于非線程安全前弯,效率上可能高于 Hashtable蚪缀。
HashMap允許將null作為一個entry 的key 或者value,而Hashtable不允許恕出。
HashMap把Hashtable的contains方法去掉了询枚,改成containsvalue和containsKey。因為contains
方法容易讓人引起誤解浙巫。
Hashtable繼承自Dictionary 類哩盲,而HashMap是 Java1.2 引進的Map interface 的一個實現(xiàn)。
最大的不同是狈醉,Hashtable 的方法是 Synchronize 的廉油,而 HashMap 不是,在多個線程訪問Hashtable時苗傅,不需要自己為它的方法實現(xiàn)同步抒线,而HashMap 就必須為之提供外同步。
Hashtable和HashMap采用的hash/rehash算法都大概一樣渣慕,所以性能不會有很大的差異嘶炭。
41、heap和stack有什么區(qū)別
答:棧是一種線形集合逊桦,其添加和刪除元素的操作應(yīng)在同一段完成眨猎。棧按照后進先出的方式進行處理。堆是棧的一個組成元素
42强经、Java的接口和C++的虛類的相同和不同處
答:由于 Java 不支持多繼承睡陪,而有可能某個類或?qū)ο笠褂梅謩e在幾個類或?qū)ο罄锩娴姆椒ɑ驅(qū)傩裕F(xiàn)有的單繼承機制就不能滿足要求匿情。與繼承相比兰迫,接口有更高的靈活性,因為接口中沒有任何實現(xiàn)代碼炬称。當一個類實現(xiàn)了接口以后汁果,該類要實現(xiàn)接口里面所有的方法和屬性,并且接口里面的屬性在默認狀態(tài)下面都是public static,所有方法默認情況下是public.一個類可以實現(xiàn)多個接口玲躯。
43据德、Java中的異常處理機制的簡單原理和應(yīng)用
答:當 JAVA 程序違反了 JAVA 的語義規(guī)則時鳄乏,JAVA 虛擬機就會將發(fā)生的錯誤表示為一個異常。違反語義規(guī)則包括2種情況棘利。一 種是JAVA 類庫內(nèi)置的語義檢查橱野。例如數(shù)組下標越界,會引發(fā)IndexOutOfBoundsException;訪問null的對象時會引發(fā)
NullPointerException。另一種情況就是 JAVA允許程序員擴展這種語義檢查赡译,程序員可以創(chuàng)建自己的異常仲吏,并自由選擇在何時用throw 關(guān)鍵字引發(fā)異常不铆。所有的異常都是 java.lang.Thowable 的子類蝌焚。
43、垃圾回收的優(yōu)點和原理誓斥。并考慮 2種回收機制
答:Java語言中一個顯著的特點就是引入了垃圾回收機制只洒,使 c++程序員最頭疼的內(nèi)存管理的問題迎刃而解,它使得 Java程序員在編寫程序的時候不再需要考慮內(nèi)存管理劳坑。由于有個垃圾回收機制毕谴,Java中的對象不再有"作用域"的概念,只有對象的引用才有"作用域"距芬。垃圾回收可以有效的防止內(nèi)存泄露涝开,有效的使用可以使用的內(nèi)存。垃圾回收器通常是作為一個單獨的低級別的線程運行框仔,不可預(yù)知的情況下對內(nèi)存堆中已經(jīng)死亡的或者長時間沒有使用的對象進行清楚和回收舀武,程序員不能 實時的調(diào)用垃圾回收器對某個對象或所有對象進行垃圾回收±胝叮回收機制有分代復(fù)制垃圾回收和標記垃圾回收银舱,增量垃圾回收。
44跛梗、你所知道的集合類都有哪些寻馏?主要方法?
答:最常用的集合類是 List 和 Map核偿。 List 的具體實現(xiàn)包括 ArrayList 和 Vector诚欠,它們是可
變大小的列表,比較適合構(gòu)建漾岳、存儲和操作任何類型對象的元素列表聂薪。 List 適用于按數(shù)值索引訪問元素的情形。
Map 提供了一個更通用的元素存儲方法蝗羊。 Map 集合類用于存儲元素對(稱作"鍵"和"值")藏澳,其中每個鍵映射到一個值。
45耀找、描述一下JVM加載 class文件的原理機制?
答:JVM 中類的裝載是由 ClassLoader 和它的子類來實現(xiàn)的,Java ClassLoader 是一個重要的Java運行時系統(tǒng)組件翔悠。它負責(zé)在運行時查找和裝入類文件的類业崖。
46、排序都有哪幾種方法蓄愁?請列舉
答: 排序的方法有:插入排序(直接插入排序双炕、希爾排序),交換排序(冒泡排序撮抓、快速排序)妇斤,選擇排序(直接選擇排序、堆排序)丹拯,歸并排序站超,分配排序(箱排序、基數(shù)排序)快速排序的偽代碼乖酬。
/ /使用快速排序方法對 a[ 0 :n- 1 ]排序
從a[ 0 :n- 1 ]中選擇一個元素作為 m i d d l e死相,該元素為支點 把余下的元素分割為兩段 left 和r i g h t,使得 l e f t中的元素都小于等于支點咬像,而right 中的元素都大于等于支點遞歸地使用快速排序方法對 left 進行排序遞歸地使用快速排序方法對 right 進行排序所得結(jié)果為 l e f t + m i d d l e + r i g h t
47算撮、JAVA 語言如何進行異常處理,關(guān)鍵字:throws,throw,try,catch,finally 分別代表什么意義县昂?在 try 塊中可以拋出異常嗎肮柜?
答:Java通過面向?qū)ο蟮姆椒ㄟM行異常處理,把各種不同的異常進行分類倒彰,并提供了良好的接口审洞。在Java中,每個異常都是一個對象狸驳,它是Throwable 類或其它子類的實例预明。當一個方法出現(xiàn)異常后便拋出一個異常對象,該對象中包含有異常信息耙箍,調(diào)用這個對象的方法可以捕獲到這個異常并進行處理撰糠。Java的異常處理是通過 5個關(guān)鍵詞來實現(xiàn)的:try、catch辩昆、 throw阅酪、throws和finally。一般情況下是用try 來執(zhí)行一段程序汁针,如果出現(xiàn)異常术辐,系統(tǒng)會拋出(throws)一個異常,這時候你可以通過它的類型來捕捉(catch)它施无,或最后(finally)由缺省處理器來處理辉词。 用try 來指定一塊預(yù)防所有"異常"的程序。緊跟在try程序后面猾骡,應(yīng)包含一個catch子句來指定你想要捕捉的"異常"的類型瑞躺。
throw語句用來明確地拋出一個"異常"敷搪。 throws用來標明一個成員函數(shù)可能拋出的各種"異常"。
Finally為確保一段代碼不管發(fā)生什么"異常"都被執(zhí)行一段代碼幢哨。
可以在一個成員函數(shù)調(diào)用的外面寫一個 try 語句赡勘,在這個成員函數(shù)內(nèi)部寫另一個 try 語句保護其他代碼。每當遇到一個 try 語句捞镰,"異常"的框架就放到堆棧上面闸与,直到所有的 try 語句都完成。如果下一級的 try 語句沒有對某種"異常"進行處理岸售,堆棧就會展開践樱,直到遇到有處理這種"異常"的try語句。
48冰评、一個".java"源文件中是否可以包括多個類(不是內(nèi)部類)映胁?有什么限制木羹?
答:可以甲雅。必須只有一個類名與文件名相同。
49坑填、java中有幾種類型的流抛人?JDK 為每種類型的流提供了一些抽象類以供繼承,請說出他們
分別是哪些類脐瑰?
答:字節(jié)流妖枚,字符流。字節(jié)流繼承于 InputStream OutputStream苍在,字符流繼承于
InputStreamReader OutputStreamWriter 绝页。在java.io包中還有許多其他的流,主要是為了提高性能和使用方便寂恬。
50续誉、java中會存在內(nèi)存泄漏嗎,請簡單描述初肉。
答:會酷鸦。自己實現(xiàn)堆載的數(shù)據(jù)結(jié)構(gòu)時有可能會出現(xiàn)內(nèi)存泄露,可參看effective java.
51牙咏、java中實現(xiàn)多態(tài)的機制是什么臼隔?
答:方法的重寫 Overriding 和重載 Overloading 是 Java 多態(tài)性的不同表現(xiàn)。重寫 Overriding是父類與子類之間多態(tài)性的一種表現(xiàn)妄壶,重載Overloading是一個類中多態(tài)性的一種表現(xiàn)摔握。
52、垃圾回收器的基本原理是什么丁寄?垃圾回收器可以馬上回收內(nèi)存嗎氨淌?有什么辦法主動通知虛擬機進行垃圾回收
答:對于 GC 來說遣耍,當程序員創(chuàng)建對象時,GC 就開始監(jiān)控這個對象的地址颠锉、大小以及使用情況蓖议。通常,GC采用有向圖的方式記錄和管理堆(heap)中的所有對象蛮艰。通過這種方式確定哪些對象是"可達的"腋腮,哪些對象是"不可達的"。當GC確定一些對象為"不可達"時壤蚜,GC 就有責(zé)任回收這些內(nèi)存空間即寡。可以袜刷。程序員可以手動執(zhí)行 System.gc()聪富,通知GC運行,但是Java語言規(guī)范并不保證GC一定會執(zhí)行著蟹。
53墩蔓、靜態(tài)變量和實例變量的區(qū)別?
答:static i = 10; //常量 class A a; a.i =10;//可變
54萧豆、什么是java序列化奸披,如何實現(xiàn) java序列化?
答:序列化就是一種用來處理對象流的機制涮雷,所謂對象流也就是將對象的內(nèi)容進行流化阵面。可以對流化后的對象進行讀寫操作洪鸭,也可將流化后的對象傳輸于網(wǎng)絡(luò)之間样刷。序列化是為了解決在對對象流進行讀寫操作時所引發(fā)的問題。
序列化的實現(xiàn):將需要被序列化的類實現(xiàn) Serializable 接口览爵,該接口沒有需要實現(xiàn)的方法置鼻,
implements Serializable 只是為了標注該對象是可被序列化的,然后使用一個輸出流(如:FileOutputStream)來構(gòu)造一個ObjectOutputStream(對象流) 對象拾枣,接著沃疮,使用 ObjectOutputStream 對象的writeObject(Object obj)方法就可以將參數(shù)為obj的對象寫出(即保存其狀態(tài)),要恢復(fù)的話則用輸入流梅肤。
55司蔬、是否可以從一個static方法內(nèi)部發(fā)出對非static方法的調(diào)用?
答:不可以,如果其中包含對象的 method()姨蝴;不能保證對象初始化.
56俊啼、寫clone()方法時,通常都有一行代碼左医,是什么授帕?
答:Clone 有缺省行為同木,super.clone();他負責(zé)產(chǎn)生正確大小的空間,并逐位復(fù)制跛十。
57彤路、在JAVA中,如何跳出當前的多重嵌套循環(huán)芥映? 答:用break; return 方法洲尊。
58、List奈偏、Map坞嘀、Set三個接口,存取元素時惊来,各有什么特點丽涩?
答:List 以特定次序來持有元素,可有重復(fù)元素裁蚁。Set 無法擁有重復(fù)元素,內(nèi)部排序矢渊。Map 保存key-value 值,value 可多值厘擂。
59昆淡、說出一些常用的類锰瘸,包刽严,接口,請各舉5 個
答:常用的類:BufferedReader BufferedWriter FileReader FileWirter String Integer
常用的包:java.lang java.awt java.io java.util java.sql
常用的接口:Remote List Map Document NodeList
60避凝、java 中有幾種方法可以實現(xiàn)一個線程舞萄?用什么關(guān)鍵字修飾同步方法? stop()和 suspend()
方法為何不推薦使用?
答:有兩種實現(xiàn)方法管削,分別是繼承 Thread類與實現(xiàn)Runnable接口 用synchronized關(guān)鍵字修飾同步方法
反對使用stop()倒脓,是因為它不安全。它會解除由線程獲取的所有鎖定含思,而且如果對象處于一種不連貫狀態(tài)崎弃,那么其他線程能在那種狀態(tài)下檢查和修改它們。結(jié)果很難檢查出真正的問題所在含潘。suspend()方法容易發(fā)生死鎖饲做。調(diào)用suspend()的時候,目標線程會停下來遏弱,但卻仍然持有在這之前獲得的鎖定盆均。此時,其他任何線程都不能訪問鎖定的資源漱逸,除非被"掛起" 的線程恢復(fù)運行泪姨。對任何線程來說游沿,如果它們想恢復(fù)目標線程,同時又試圖使用任何一個鎖定的資源肮砾,就會造成死鎖诀黍。所以不應(yīng)該使用suspend(),而應(yīng)在自己的Thread類中置入一個標志仗处,指出線程應(yīng)該活動還是掛起蔗草。若標志指出線程應(yīng)該掛起,便用wait()命其進入等待狀態(tài)疆柔。若標志指出線程應(yīng)當恢復(fù)咒精,則用一個 notify()重新啟動線程。
61旷档、sleep() 和 wait() 有什么區(qū)別?
答:sleep 是線程類(Thread)的方法模叙,導(dǎo)致此線程暫停執(zhí)行指定時間,給執(zhí)行機會給其他線程鞋屈,但是監(jiān)控狀態(tài)依然保持范咨, 到時后會自動恢復(fù)。調(diào)用 sleep不會釋放對象鎖厂庇。
wait 是 Object 類的方法渠啊,對此對象調(diào)用 wait 方法導(dǎo)致本線程放棄對象鎖,進入等待此對象的等待鎖定池权旷,只有針對此對象發(fā)出notify 方法(或notifyAll)后本線程才進入對象鎖定池準備獲得對象鎖進入運行狀態(tài)替蛉。
62、同步和異步有何異同拄氯,在什么情況下分別使用他們躲查?舉例說明。
答:如果數(shù)據(jù)將在線程間共享译柏。例如正在寫的數(shù)據(jù)以后可能被另一個線程讀到镣煮,或者正在讀的數(shù)據(jù)可能已經(jīng)被另一個線程寫過了,那么這些數(shù)據(jù)就是共享數(shù)據(jù)鄙麦,必須進行同步存取典唇。
當應(yīng)用程序在對象上調(diào)用了一個需要花費很長時間來執(zhí)行的方法,并且不希望讓程序等待方法的返回時胯府,就應(yīng)該使用異步編程介衔,在很多情況下采用異步途徑往往更有效率。
63盟劫、啟動一個線程是用 run()還是start()?
答:啟動一個線程是調(diào)用 start()方法夜牡,使線程所代表的虛擬處理機處于可運行狀態(tài),這意味著它可以由JVM調(diào)度并執(zhí)行。
這并不意味著線程就會立即運行塘装。run()方法可以產(chǎn)生必須退出的標志來停止一個線程急迂。
64、當一個線程進入一個對象的一個synchronized方法后蹦肴,其它線程是否可進入此對象的其它方法?
答:不能僚碎,一個對象的一個 synchronized方法只能由一個線程訪問。
65阴幌、請說出你所知道的線程同步的方法勺阐。
答:wait():使一個線程處于等待狀態(tài),并且釋放所持有的對象的 lock矛双。 sleep():使一個正在運行的線程處于睡眠狀態(tài)渊抽,是一個靜態(tài)方法,調(diào)用此方法要捕捉InterruptedException 異常议忽。
notify():喚醒一個處于等待狀態(tài)的線程懒闷,注意的是在調(diào)用此方法的時候,并不能確切的喚醒某一個等待狀態(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)之間的關(guān)系
答:線程指在程序執(zhí)行過程中,能夠執(zhí)行程序代碼的一個執(zhí)行單位渣触,每個程序至少都有一個線程,也就是程序本身壹若。
Java中的線程有四種狀態(tài)分別是:運行嗅钻、就緒、掛起店展、結(jié)束
68养篓、簡述synchronized和java.util.concurrent.locks.Lock的異同 ?
答:主要相同點:Lock能完成synchronized所實現(xiàn)的所有功能
主要不同點:Lock 有比 synchronized 更精確的線程語義和更好的性能赂蕴。synchronized 會自動釋放鎖柳弄,而Lock一定要求程序員手工釋放,并且必須在 finally從句中釋放。
Jsp方面
69碧注、forward 和redirect的區(qū)別
答:forward 是服務(wù)器請求資源嚣伐,服務(wù)器直接訪問目標地址的 URL,把那個 URL 的響應(yīng)內(nèi)容讀取過來萍丐,然后把這些內(nèi)容再發(fā)給瀏覽器轩端,瀏覽器根本不知道服務(wù)器發(fā)送的內(nèi)容是從哪兒來的,所以它的地址欄中還是原來的地址逝变。
redirect 就是服務(wù)端根據(jù)邏輯,發(fā)送一個狀態(tài)碼,告訴瀏覽器重新去請求那個地址基茵,一般來說
瀏覽器會用剛才請求的所 有參數(shù)重新請求,所以 session,request參數(shù)都可以獲取壳影。
70拱层、jsp有哪些內(nèi)置對象?作用分別是什么?
答:JSP共有以下9 種基本內(nèi)置組件(可與 ASP的6種內(nèi)部組件相對應(yīng)):
request 用戶端請求,此請求會包含來自 GET/POST請求的參數(shù)
response 網(wǎng)頁傳回用戶端的回應(yīng)
pageContext 網(wǎng)頁的屬性是在這里管理
session 與請求有關(guān)的會話期
application servlet 正在執(zhí)行的內(nèi)容
out 用來傳送回應(yīng)的輸出
config servlet的構(gòu)架部件
page JSP網(wǎng)頁本身
exception 針對錯誤網(wǎng)頁宴咧,未捕捉的例外
71舱呻、jsp有哪些動作?作用分別是什么?
答:JSP共有以下6 種基本動作
jsp:include:在頁面被請求的時候引入一個文件。
jsp:useBean:尋找或者實例化一個 JavaBean悠汽。
jsp:setProperty:設(shè)置JavaBean 的屬性箱吕。
jsp:getProperty:輸出某個JavaBean的屬性。
jsp:forward:把請求轉(zhuǎn)到一個新的頁面柿冲。
jsp:plugin:根據(jù)瀏覽器類型為 Java插件生成OBJECT 或EMBED標記
72茬高、JSP中動態(tài)INCLUDE 與靜態(tài)INCLUDE的區(qū)別?
答:動態(tài)INCLUDE用jsp:include 動作實現(xiàn)
<jsp:include page="included.jsp" flush="true" />它總是會檢查所含文件中的變化假抄,適合用于包含動態(tài)頁面怎栽,并且可以帶參數(shù)靜態(tài)INCLUDE用include 偽碼實現(xiàn),定不會檢查所含文件的變化,適用于包含靜態(tài)頁面 <%@ include file="included.htm" %>
73宿饱、兩種跳轉(zhuǎn)方式分別是什么?有什么區(qū)別?
答:有兩種熏瞄,分別為:
<jsp:include page="included.jsp" flush="true">
<jsp:forward page= "nextpage.jsp"/>
前者頁面不會轉(zhuǎn)向 include 所指的頁面,只是顯示該頁的結(jié)果谬以,主頁面還是原來的頁面强饮。執(zhí)行完后還會回來,相當于函數(shù)調(diào)用为黎。并且可以帶參數(shù).后者完全轉(zhuǎn)向新頁面邮丰,不會再回來。相當于 go to 語句铭乾。
74剪廉、JSP的內(nèi)置對象及方法。
答:request表示HttpServletRequest對象炕檩。它包含了有關(guān)瀏覽器請求的信息斗蒋,并且提供了幾個用于獲取cookie, header, 和session數(shù)據(jù)的有用的方法。
response表示HttpServletResponse 對象,并提供了幾個用于設(shè)置送回 瀏覽器的響應(yīng)的方法
(如cookies,頭信息等)
out對象是javax.jsp.JspWriter的一個實例泉沾,并提供了幾個方法使你能用于向瀏覽器回送輸出
結(jié)果捞蚂。
pageContext表示一個 javax.servlet.jsp.PageContext對象。它是用于方便存取各種范圍的名字
空間爆哑、servlet相關(guān)的對象的API洞难,并且包裝了通用的servlet相關(guān)功能的方法。
session表示一個請求的 javax.servlet.http.HttpSession對象揭朝。 Session可以存貯用戶的狀態(tài)信息
applicaton 表示一個javax.servle.ServletContext對象队贱。這有助于查找有關(guān)servlet引擎和servlet
環(huán)境的信息
config表示一個javax.servlet.ServletConfig對象。該對象用于存取servlet實例的初始化參數(shù)潭袱。
page 表示從該頁面產(chǎn)生的一個 servlet實例
Servlet方面
75柱嫌、說一說Servlet的生命周期?
答:servlet 有良好的生存期的定義,包括加載和實例化屯换、初始化编丘、處理請求以及服務(wù)結(jié)束。
這個生存期由 javax.servlet.Servlet 接口的 init,service 和 destroy 方法表達彤悔。 Servlet 被服務(wù)器實例化后嘉抓,容器運行其init方法,請求到達時運行其service方法晕窑, service方法自動派遣運行與請求對應(yīng)的doXXX方法(doGet抑片,doPost)等,當服務(wù)器決定將實例銷毀的時候調(diào)用其 destroy方法杨赤。
與 cgi 的區(qū)別在于 servlet 處于服務(wù)器進程中敞斋,它通過多線程方式運行其 service 方法,一個實例可以服務(wù)于多個請求疾牲,并且其實例一般不會銷毀植捎,而 CGI對每個請求都產(chǎn)生新的進程,服務(wù)完成后就銷毀阳柔,所以效率上低于servlet焰枢。
76、JAVA SERVLET API中 forward() 與redirect()的區(qū)別盔沫?
答:前者僅是容器中控制權(quán)的轉(zhuǎn)向医咨,在客戶端瀏覽器地址欄中不會顯示出轉(zhuǎn)向后的地址;后者則是完全的跳轉(zhuǎn)架诞,瀏覽器將會得到跳轉(zhuǎn)的地址,并重新發(fā)送請求鏈接干茉。這樣谴忧,從瀏覽器的地址欄中可以看到跳轉(zhuǎn)后的鏈接地址。所以,前者更加高效沾谓, 在前者可以滿足需要時委造,盡量使用 forward()方法,并且均驶,這樣也有助于隱藏實際的鏈接昏兆。
在有些情況下,比如妇穴,需要跳轉(zhuǎn) 到一個其它服務(wù)器上的資源爬虱,則必須使用sendRedirect()方法。
77腾它、Servlet的基本架構(gòu)
答:
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跑筝、什么情況下調(diào)用doGet()和doPost()?
答: Jsp頁面中的form標簽里的method屬性為get時調(diào)用doGet()瞒滴,為post時調(diào)用doPost()曲梗。
79、servlet的生命周期
答:web容器加載servlet妓忍,生命周期開始虏两。通過調(diào)用servlet的init()方法進行servlet的初始化。通過調(diào)用service()方法實現(xiàn)世剖,根據(jù)請求的不同調(diào)用不同的 do***()方法定罢。結(jié)束服務(wù), web容器調(diào)用servlet的 destroy()方法搁廓。
80引颈、如何現(xiàn)實servlet的單線程模式
答:<%@ page isThreadSafe="false"%>
81、頁面間對象傳遞的方法
答:request境蜕,session蝙场,application,cookie 等
82粱年、JSP和 Servlet有哪些相同點和不同點售滤,他們之間的聯(lián)系是什么?
答:JSP 是 Servlet技術(shù)的擴展台诗,本質(zhì)上是 Servlet 的簡易方式完箩,更強調(diào)應(yīng)用的外表表達。JSP編譯后是"類servlet"拉队。
Servlet 和 JSP 最主要的不同點在于弊知,Servlet 的應(yīng)用邏輯是在 Java 文件中,并且完全從表示層中的HTML里分離開來粱快。而 JSP 的情況是 Java 和 HTML 可以組合成一個擴展名為.jsp 的文件秩彤。JSP 側(cè)重于視圖叔扼,Servlet 主要用于控制邏輯。
83漫雷、四種會話跟蹤技術(shù)
答:會話作用域ServletsJSP 頁面描述page 否是代表與一個頁面相關(guān)的對象和屬性瓜富。一個頁面由一個編譯好的 Java servlet 類(可以帶有任何的 include 指令,但是沒有 include 動作)表示降盹。這既包括 servlet 又包括被編譯成 servlet 的 JSP 頁面 request 是是代表與 Web 客戶機發(fā)出的一個請求相關(guān)的對象和屬性与柑。一個請求可能跨越多個頁面,涉及多個 Web 組件(由于 forward 指令和 include 動作的關(guān)系) session是是代表與用于某個 Web 客戶機的一個用戶體驗相關(guān)的對象和屬性蓄坏。一個 Web 會話可以也經(jīng)常會跨越多個客戶機請求
application 是代表與整個 Web 應(yīng)用程序相關(guān)的對象和屬性价捧。這實質(zhì)上是跨越整個 Web 應(yīng)用程序,包括多個頁面剑辫、請求和會話的一個全局作用域
84干旧、Request對象的主要方法
答:
setAttribute(String name,Object):設(shè)置名字為name的 request的參數(shù)值
getAttribute(String name):返回由name指定的屬性值
getAttributeNames():返回request對象所有屬性的名字集合,結(jié)果是一個枚舉的實例
getCookies():返回客戶端的所有 Cookie對象妹蔽,結(jié)果是一個 Cookie數(shù)組
getCharacterEncoding():返回請求中的字符編碼方式
getContentLength():返回請求的 Body的長度
getHeader(String name):獲得HTTP協(xié)議定義的文件頭信息
getHeaders(String name):返回指定名字的request Header的所有值椎眯,結(jié)果是一個枚舉的實例
getHeaderNames():返回所以 request Header的名字,結(jié)果是一個枚舉的實例
getInputStream():返回請求的輸入流胳岂,用于獲得請求中的數(shù)據(jù)
getMethod():獲得客戶端向服務(wù)器端傳送數(shù)據(jù)的方法
getParameter(String name):獲得客戶端傳送給服務(wù)器端的有name 指定的參數(shù)值
getParameterNames():獲得客戶端傳送給服務(wù)器端的所有參數(shù)的名字编整,結(jié)果是一個枚舉的實例
getParameterValues(String name):獲得有name 指定的參數(shù)的所有值
getProtocol():獲取客戶端向服務(wù)器端傳送數(shù)據(jù)所依據(jù)的協(xié)議名稱
getQueryString():獲得查詢字符串
getRequestURI():獲取發(fā)出請求字符串的客戶端地址
getRemoteAddr():獲取客戶端的 IP地址
getRemoteHost():獲取客戶端的名字
getSession([Boolean create]):返回和請求相關(guān)SessiongetServerName():獲取服務(wù)器的名字
getServletPath():獲取客戶端所請求的腳本文件的路徑
getServerPort():獲取服務(wù)器的端口號
removeAttribute(String name):刪除請求中的一個屬性
85、我們在web應(yīng)用開發(fā)過程中經(jīng)常遇到輸出某種編碼的字符乳丰,如 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;
}
86产园、Servlet執(zhí)行時一般實現(xiàn)哪幾個方法渐裸?
答:
public void init(ServletConfig config)
public ServletConfig getServletConfig()
public String getServletInfo()
public void service(ServletRequest request,ServletResponse response)
public void destroy()
Jdbc骑素、Jdo方面
87、Class.forName的作用?為什么要用?
答:調(diào)用該訪問返回一個以字符串指定類名的類的對象。
88讯柔、Jdo是什么?
答:JDO是Java對象持久化的新的規(guī)范被因,為 java data object的簡稱,也是一個用于存取某種數(shù)據(jù)倉庫中的對象的標準化 API
贡翘。JDO提供了透明的對象存儲著角,因此對開發(fā)人員來說,存儲數(shù)據(jù)對象完全不需要額外的代碼
(如JDBC API的使用)技俐。這些繁瑣的例行工作已經(jīng)轉(zhuǎn)移到 JDO 產(chǎn)品提供商身上乘陪,使開發(fā)人員解脫出來,從而集中時間和精力在業(yè)務(wù)邏輯上雕擂。另外啡邑,JDO很靈活,因為它可以在任何數(shù)據(jù)底層上運行井赌。JDBC 只是面向關(guān)系數(shù)據(jù)庫(RDBMS)JDO 更通用谣拣,提供到任何數(shù)據(jù)底層的存儲功能募寨, 比如關(guān)系數(shù)據(jù)庫族展、文件森缠、XML以及對象數(shù)據(jù)庫(ODBMS)等等,使得應(yīng)用可移植性更強仪缸。
89贵涵、說出數(shù)據(jù)連接池的工作機制是什么?
答:J2EE 服務(wù)器啟動時會建立一定數(shù)量的池連接,并一直維持不少于此數(shù)目的池連接恰画”雒客戶端程序需要連接時,池驅(qū)動程序會返回一個未使用的池連接并將其表記為忙拴还。如果當前沒有空閑連接跨晴,池驅(qū)動程序就新建一定數(shù)量的連接,新建連接的 數(shù)量有配置參數(shù)決定片林。當使用的池連接調(diào)用完成后端盆,池驅(qū)動程序?qū)⒋诉B接表記為空閑,其他調(diào)用就可以使用這個連接费封。
Xml方面
91焕妙、xml有哪些解析技術(shù)?區(qū)別是什么?
答:有DOM,SAX,STAX等
DOM:處理大型文件時其性能下降的非常厲害。這個問題是由 DOM的樹結(jié)構(gòu)所造成的弓摘,這種
結(jié)構(gòu)占用的內(nèi)存較多焚鹊,而且 DOM必須在解析文件之前把整個文檔裝入內(nèi)存,適合對XML的隨機訪問SAX:不現(xiàn)于DOM,SAX是事件驅(qū)動型的XML解析方式。它順序讀取 XML 文件韧献,不需要一次全部裝載整個文件末患。當遇到像文件開頭,文檔結(jié)束锤窑,或者標簽開頭與標簽結(jié)束時璧针,它會觸發(fā)一個事件,用戶通過在其回調(diào)事件中寫入處理代碼來處理XML文件果复,適合對XML的順序訪問
STAX:Streaming API for XML (StAX)
92陈莽、你在項目中用到了 xml技術(shù)的哪些方面?如何實現(xiàn)的?
答:用到了數(shù)據(jù)存貯,信息配置兩方面虽抄。在做數(shù)據(jù)交換平臺時走搁,將不能數(shù)據(jù)源的數(shù)據(jù)組裝成XML文件,然后將XML文件壓縮打包加密后通過網(wǎng)絡(luò)傳送給接收者迈窟,接收解密與解壓縮后再同 XML 文件中還原相關(guān)信息進行處理私植。在做軟件配置時,利用XML可以很方便的進行车酣,軟件的各種配置參數(shù)都存貯在XML文件中曲稼。
93索绪、XML文檔定義有幾種形式?它們之間有何本質(zhì)區(qū)別贫悄?解析 XML 文檔有哪幾種方式瑞驱?
答:a: 兩種形式 dtd schema,b: 本質(zhì)區(qū)別:schema本身是xml的窄坦,可以被XML 解析器解析
(這也是從DTD上發(fā)展 schema的根本目的)唤反,c:有DOM,SAX,STAX等
DOM:處理大型文件時其性能下降的非常厲害。這個問題是由 DOM的樹結(jié)構(gòu)所造成的鸭津,這種結(jié)構(gòu)占用的內(nèi)存較多彤侍,而且DOM必須在解析文件之前把整個文檔裝入內(nèi)存,適合對 XML 的隨機訪問
SAX:不現(xiàn)于DOM,SAX 是事件驅(qū)動型的 XML 解析方式。它順序讀取XML 文件逆趋,不需要一次全
部裝載整個文件盏阶。當遇到像文件開頭,文檔結(jié)束闻书,或者標簽開頭與標簽結(jié)束時名斟,它會觸發(fā)一個事件,用戶通過在其回調(diào)事件中寫入處理代碼來處理XML文件惠窄, 適合對XML 的順序訪問
STAX:Streaming API for XML (StAX)
EJB 方面
94蒸眠、EJB2.0 有哪些內(nèi)容?分別用在什么場合? EJB2.0和 EJB1.1 的區(qū)別?
答:規(guī)范內(nèi)容包括 Bean 提供者,應(yīng)用程序裝配者杆融,EJB 容器楞卡,EJB 配置工具,EJB 服務(wù)提供者脾歇,系統(tǒng)管理員蒋腮。這里面,EJB容器是 EJB 之所以能夠運行的核心藕各。EJB 容器管理著 EJB 的創(chuàng)建池摧,撤消,激活激况,去活作彤,與數(shù)據(jù)庫的連接等等重要的核心工作。
JSP,Servlet,EJB,JNDI,JDBC,JMS.....
95乌逐、EJB 與JAVA BEAN 的區(qū)別竭讳?
答:Java Bean 是可復(fù)用的組件,對 Java Bean并沒有嚴格的規(guī)范浙踢,理論上講绢慢,任何一個 Java類都可以是一個Bean。但通常情況下洛波,由于Java Bean 是被容器所創(chuàng)建(如Tomcat)的胰舆,所以Java Bean應(yīng)具有一個無參的構(gòu)造器骚露,另外,通常Java Bean 還要實現(xiàn)Serializable接口用于實現(xiàn) Bean的持久性缚窿。Java Bean 實際上相當于微軟 COM模型中的本地進程內(nèi)COM組件棘幸,它是不能被跨進程訪問的。Enterprise Java Bean 相當于DCOM滨攻,即分布式組件够话。它是基于 Java的遠程方法調(diào)用(RMI)技術(shù)的,所以EJB 可以被遠程訪問(跨進程光绕、跨計算機)。但EJB必須被布署在諸如Webspere畜份、 WebLogic這樣的容器中诞帐,EJB客戶從不直接訪問真正的EJB組件,而是通過其容器訪問爆雹。EJB 容器是EJB組件的代理停蕉,EJB 組件由容器所創(chuàng)建和管理「铺客戶通過容器來訪問真正的EJB 組件慧起。
96、EJB 是基于哪些技術(shù)實現(xiàn)的册倒?并說出 SessionBean和 EntityBean的區(qū)別蚓挤,StatefulBean 和StatelessBean的區(qū)別。
答:EJB包括Session Bean驻子、Entity Bean灿意、Message Driven Bean,基于JNDI崇呵、RMI缤剧、JAT 等技術(shù)實現(xiàn)。
SessionBean在J2EE 應(yīng)用程序中被用來完成一些服務(wù)器端的業(yè)務(wù)操作域慷,例如訪問數(shù)據(jù)庫荒辕、調(diào)用其他EJB組件。EntityBean被用來代表應(yīng)用系統(tǒng)中用到的數(shù)據(jù)犹褒。
對于客戶機抵窒,SessionBean是一種非持久性對象,它實現(xiàn)某些在服務(wù)器上運行的業(yè)務(wù)邏輯化漆。
對于客戶機估脆,EntityBean是一種持久性對象,它代表一個存儲在持久性存儲器中的實體的對象視圖座云,或是一個由現(xiàn)有企業(yè) 應(yīng)用程序?qū)崿F(xiàn)的實體疙赠。
Session Bean 還可以再細分為 Stateful Session Bean 與 Stateless Session Bean 付材,這兩種的Session Bean都可以將系統(tǒng)邏輯放在 method 之中執(zhí)行,不同的是 Stateful Session Bean 可以記錄呼叫者的狀態(tài)圃阳,因此通常來說厌衔,一個使用者會有一個相對應(yīng)的 Stateful Session Bean 的實體。Stateless Session Bean 雖然也是邏輯組件捍岳,但是他卻不負責(zé)記錄使用者狀態(tài)富寿,也就是說當使用者呼叫 Stateless Session Bean 的時候,EJB Container 并不會找尋特定的 Stateless
Session Bean 的實體來執(zhí)行這個 method锣夹。換言之页徐,很可能數(shù)個使用者在執(zhí)行某個 Stateless
Session Bean 的 methods 時,會是同一個 Bean 的 Instance 在執(zhí)行银萍。從內(nèi)存方面來看变勇, Stateful Session Bean 與 Stateless Session Bean 比較, Stateful Session Bean 會消耗 J2EE Server 較多的內(nèi)存贴唇,然而 Stateful Session Bean 的優(yōu)勢卻在于他可以維持使用者的狀態(tài)搀绣。
97、EJB 與JAVA BEAN 的區(qū)別戳气?
答:Java Bean 是可復(fù)用的組件链患,對 Java Bean并沒有嚴格的規(guī)范,理論上講瓶您,任何一個 Java類都可以是一個Bean麻捻。但通常情況下,由于Java Bean是被容器所創(chuàng)建(如Tomcat)的览闰,所以Java Bean應(yīng)具有一個無參的構(gòu)造器芯肤,另外,通常 Java Bean還要實現(xiàn)Serializable接口用于實現(xiàn) Bean的持久性压鉴。Java Bean 實際上相當于微軟 COM模型中的本地進程內(nèi)COM組件崖咨,它是不能被跨進程訪問的。Enterprise Java Bean 相當于DCOM油吭,即分布式組件击蹲。它是基于 Java的遠程方法調(diào)用(RMI)技術(shù)的, 所以EJB 可以被遠程訪問(跨進程婉宰、跨計算機)歌豺。但EJB必須被布署在諸如Webspere、 WebLogic這樣的容器中心包,EJB客戶從不直接訪問真正的EJB組件类咧,而是通過其容器訪問。EJB 容器是EJB組件的代理,EJB 組件由容器所創(chuàng)建和管理痕惋∏睿客戶通過容器來訪問真正的EJB 組件。
EJB 包括(SessionBean,EntityBean)說出他們的生命周期值戳,及如何管理事務(wù)的议谷?
SessionBean:Stateless Session Bean 的生命周期是由容器決定的,當客戶機發(fā)出請求要建立一個Bean的實例時堕虹,EJB容器不一定要創(chuàng)建一個新的Bean的實例供客戶機調(diào)用卧晓,而是隨便找一個現(xiàn)有的實例提供給客戶機。當客戶機第一次調(diào)用一個Stateful Session Bean 時赴捞,容器必須立即在服務(wù)器中創(chuàng)建一個新的 Bean實例逼裆,并關(guān)聯(lián)到客戶機上,以后此客戶機調(diào)用Stateful Session Bean 的方法時容器會把調(diào)用分派到與此客戶機相關(guān)聯(lián)的 Bean實例螟炫。
EntityBean:Entity Beans能存活相對較長的時間波附,并且狀態(tài)是持續(xù)的。只要數(shù)據(jù)庫中的數(shù)據(jù)存在昼钻,Entity beans就一直存活。而不是按照應(yīng)用程序或者服務(wù)進程來說的封寞。即使 EJB 容器崩潰了然评,Entity beans 也是
存活的。Entity Beans生命周期能夠被容器或者 Beans自己管理狈究。
EJB 通過以下技術(shù)管理實務(wù):對象管理組織(OMG)的對象實務(wù)服務(wù)(OTS)碗淌, Sun Microsystems
的Transaction Service(JTS)、Java Transaction API(JTA)抖锥,開發(fā)組(X/Open)的XA接口亿眠。
98、EJB 的角色和三個對象
答:一個完整的基于EJB的分布式計算結(jié)構(gòu)由六個角色組成磅废,這六個角色可以由不同的開發(fā)商提供纳像,每個角色所作的工作必須遵循Sun公司提供的 EJB 規(guī)范,以保證彼此之間的兼容性拯勉。這六個角色分別是 EJB 組件開發(fā)者(Enterprise Bean Provider)竟趾、應(yīng)用組合者(Application Assembler)、部署者(Deployer)宫峦、EJB 服務(wù)器提供者(EJB Server Provider)岔帽、EJB容器提供者(EJB Container Provider)、系統(tǒng)管理員(System Administrator)
三個對象是Remote(Local)接口导绷、Home(LocalHome)接口犀勒,Bean類
99、EJB 容器提供的服務(wù)
答:主要提供聲明周期管理、代碼產(chǎn)生贾费、持續(xù)性管理钦购、安全、事務(wù)管理铸本、鎖和并發(fā)行管理等服務(wù)肮雨。
100、EJB規(guī)范規(guī)定EJB中禁止的操作有哪些箱玷?
答:1.不能操作線程和線程 API(線程API指非線程對象的方法如 notify,wait等)怨规,2.不能操作awt,3.不能實現(xiàn)服務(wù)器功能锡足,4.不能對靜態(tài)屬生存取波丰,5.不能使用IO操作直接存取文件系統(tǒng),6.不能加載本地庫.舶得,7.
不能將this作為變量和返回掰烟, 8.不能循環(huán)調(diào)用。
101沐批、remote 接口和home接口主要作用
答:remote接口定義了業(yè)務(wù)方法纫骑,用于 EJB 客戶端調(diào)用業(yè)務(wù)方法。
home 接口是EJB工廠用于創(chuàng)建和移除查找 EJB實例
102九孩、bean 實例的生命周期
答:對于Stateless Session Bean先馆、Entity Bean、Message Driven Bean一般存在緩沖池管理躺彬,而對于Entity Bean和Statefull Session Bean 存在 Cache 管理煤墙,通常包含創(chuàng)建實例,設(shè)置上下文宪拥、創(chuàng)建 EJB Object
(create)仿野、業(yè)務(wù)方法調(diào)用、remove等過程她君,對于存在緩沖池管理的 Bean脚作,在 create 之后實例并不從內(nèi)存清除,而是采用緩沖池調(diào)度機制不斷重用實例犁河,而對于存在Cache管理的 Bean則通過激活和去激活機制保持Bean的狀態(tài)并限制內(nèi)存中實例數(shù)量鳖枕。
103、EJB的激活機制
答:以Stateful Session Bean 為例:其Cache 大小決定了內(nèi)存中可以同時存在的 Bean實例的
數(shù)量桨螺,根據(jù)MRU或NRU算法宾符,實例在激活和去激活狀態(tài)之間遷移,激活機制是當客戶端調(diào)用某個 EJB 實例業(yè)務(wù)方法時灭翔,如果對應(yīng)EJB Object發(fā)現(xiàn)自己沒有綁定對應(yīng)的 Bean 實例則從其去激活 Bean 存儲中(通過序列化機制存儲實例)回復(fù)(激活)此實例魏烫。狀態(tài)變遷前會調(diào)用對應(yīng)的ejbActive和ejbPassivate 方法辣苏。
104、EJB的幾種類型
答:會話(Session)Bean 哄褒,實體(Entity)Bean 消息驅(qū)動的(Message Driven)Bean 會話Bean又可分為有狀態(tài)(Stateful)和無狀態(tài)(Stateless)兩種實體Bean可分為Bean 管理的持續(xù)性(BMP)和容器管理的持續(xù)性(CMP)兩種
105稀蟋、客服端調(diào)用EJB 對象的幾個基本步驟
答:設(shè)置JNDI服務(wù)工廠以及 JNDI服務(wù)地址系統(tǒng)屬性,查找 Home 接口呐赡,從Home 接口調(diào)用Create 方法創(chuàng)建Remote接口退客,通過Remote 接口調(diào)用其業(yè)務(wù)方法。
應(yīng)用服務(wù)器方面
106链嘀、如何給weblogic指定大小的內(nèi)存?
答:在啟動 Weblogic 的腳本中(位于所在 Domian 對應(yīng)服務(wù)器目錄下的 startServerName)萌狂,
增加set MEM_ARGS=-Xms32m -Xmx200m,可以調(diào)整最小內(nèi)存為 32M怀泊,最大200M
EJB 需直接實現(xiàn)它的業(yè)務(wù)接口或Home接口嗎茫藏,請簡述理由。
遠程接口和Home 接口不需要直接實現(xiàn)霹琼,他們的實現(xiàn)代碼是由服務(wù)器產(chǎn)生的务傲,程序運行中對
應(yīng)實現(xiàn)類會作為對應(yīng)接口類型的實例被使用。
107枣申、應(yīng)用服務(wù)器有那些售葡?
答: BEA WebLogic Server, IBM WebSphere Application Server忠藤, Oracle9i Application Server天通, jBoss,
Tomcat
108熄驼、如何設(shè)定的weblogic的熱啟動模式(開發(fā)模式)與產(chǎn)品發(fā)布模式?
答:可以在管理控制臺中修改對應(yīng)服務(wù)器的啟動模式為開發(fā)或產(chǎn)品模式之一『姹或者修改服務(wù)的啟動文件或者commenv文件瓜贾, 增加set PRODUCTION_MODE=true。
109携悯、如何啟動時不需輸入用戶名與密碼?
答:修改服務(wù)啟動文件祭芦,增加 WLS_USER 和 WLS_PW 項。也可以在 boot.properties 文件中增加加密過的用戶名和密碼.
110憔鬼、在 weblogic 管理制臺中對一個應(yīng)用域(或者說是一個網(wǎng)站,Domain)進行 jms 及 ejb 或連
接池等相關(guān)信息進行配置后,實際保存在什么文件中?
答:保存在此Domain的config.xml文件中龟劲,它是服務(wù)器的核心配置文件。
111轴或、說說 weblogic 中一個 Domain 的缺省目錄結(jié)構(gòu)?比如要將一個簡單的 helloWorld.jsp 放
入何目錄下,然的在瀏覽器上就可打入 http://主機:端口號//helloword.jsp 就可以看到運行結(jié)果了? 又比如這其中用到了一個自己寫的javaBean該如何辦?
答:Domain 目錄服務(wù)器目錄 applications昌跌,將應(yīng)用目錄放在此目錄下將可以作為應(yīng)用訪問,如果是Web應(yīng)用照雁,應(yīng)用目錄需要滿足Web應(yīng)用目錄要求蚕愤,jsp文件可以直接放在應(yīng)用目錄中,Javabean需要放在應(yīng)用目錄的WEB-INF目錄的classes目錄中, 設(shè)置服務(wù)器的缺省應(yīng)用將可以實現(xiàn)在瀏覽器上無需輸入應(yīng)用名萍诱。
112悬嗓、在 weblogic中發(fā)布 ejb需涉及到哪些配置文件
答 : 不同類型的 EJB涉及的配置文件不同,都涉及到的配置文件包括ejb-jar.xml,weblogic-ejb-jar.xmlCMP實體Bean一般 還需要weblogic-cmp-rdbms-jar.xml
113裕坊、如何查看在weblogic中已經(jīng)發(fā)布的EJB?
答:可以使用管理控制臺包竹,在它的 Deployment中可以查看所有已發(fā)布的EJB
說說在weblogic中開發(fā)消息 Bean時的persistent與non-persisten 的差別
persistent方式的MDB可以保證消息傳遞的可靠性,也就是如果EJB容器出現(xiàn)問題而JMS服務(wù)器依然會將消息在此MDB可用的時候發(fā)送過來,而non-persistent方式的消息將被丟棄籍凝。
J2EE,MVC方面
114周瞎、MVC的各個部分都有那些技術(shù)來實現(xiàn)?如何實現(xiàn)?
答:MVC 是 Model-View-Controller 的簡寫。"Model" 代表的是應(yīng)用的業(yè)務(wù)邏輯(通過JavaBean静浴,EJB 組件實現(xiàn))堰氓, "View" 是應(yīng)用的表示面(由 JSP頁面產(chǎn)生),"Controller" 是提供應(yīng)用的處理過程控制(一般是一個Servlet)苹享,通過這種設(shè)計模型把應(yīng)用邏輯双絮,處理過程和顯示邏輯分成不同的組件實現(xiàn)。這些組件可以進行交互和重用得问。
115囤攀、J2EE 是什么?
答:Je22 是Sun公司提出的多層(multi-diered),分布式(distributed),基于組件(component-base)的企業(yè)級應(yīng)用模型(enterpriese application model).在這樣的一個應(yīng)用系統(tǒng)中宫纬,可按照功能劃分為不同的組件焚挠,這些組件又可在不同計算機上,并且處于相應(yīng)的層次(tier)中漓骚。所屬層次包括客戶層(clietn tier)組件,web 層和組件,Business層和組件,企業(yè)信息系統(tǒng)(EIS)層蝌衔。
116、WEB SERVICE 名詞解釋蝌蹂。JSWDL開發(fā)包的介紹噩斟。JAXP、JAXM的解釋孤个。SOAP剃允、UDDI,WSDL
解釋。
答:Web Service 描述語言WSDL
SOAP即簡單對象訪問協(xié)議(Simple Object Access Protocol),它是用于交換XML編碼信息的輕量級協(xié)議。
UDDI 的目的是為電子商務(wù)建立標準修己;UDDI是一套基于 Web的、分布式的牡肉、為Web Service提供的、信息注冊中心的實現(xiàn)標準規(guī)范丑罪,同時也包含一組使企業(yè)能將自身提供的Web Service 注冊荚板,以使別的企業(yè)能夠發(fā)現(xiàn)的訪問協(xié)議的實現(xiàn)標準凤壁。
117、J2EE 是技術(shù)還是平臺還是框架跪另?
答:J2EE本身是一個標準拧抖,一個為企業(yè)分布式應(yīng)用的開發(fā)提供的標準平臺。
J2EE 也是一個框架免绿,包括 JDBC唧席、JNDI、RMI嘲驾、JMS淌哟、EJB、JTA 等技術(shù)辽故。
118徒仓、STRUTS的應(yīng)用(如 STRUTS架構(gòu))
答:Struts 是采用 Java Servlet/JavaServer Pages 技術(shù),開發(fā) Web 應(yīng)用程序的開放源碼的framework誊垢。 采用Struts能開發(fā)出基于MVC(Model-View-Controller)設(shè)計模式的應(yīng)用構(gòu)架掉弛。
Struts有如下的主要功能:
一.包含一個controller servlet,能將用戶的請求發(fā)送到相應(yīng)的Action對象喂走。
二.JSP自由tag庫殃饿,并且在controller servlet中提供關(guān)聯(lián)支持,幫助開發(fā)員創(chuàng)建交互式表單應(yīng)用芋肠。
三.提供了一系列實用對象:XML 處理乎芳、通過Java reflection APIs自動處理JavaBeans屬性、國際化的提示和消息帖池。
119奈惑、WEB SERVICE 名詞解釋。JSWDL開發(fā)包的介紹睡汹。JAXP携取、JAXM的解釋。SOAP帮孔、UDDI,WSDL
解釋。
答:Web ServiceWeb Service 是基于網(wǎng)絡(luò)的不撑、分布式的模塊化組件文兢,它執(zhí)行特定的任務(wù),遵守具體的技術(shù)規(guī)范焕檬,這些規(guī)范使得Web Service能與其他兼容的組件進行互操作姆坚。
JAXP(Java API for XML Parsing) 定義了在Java中使用 DOM, SAX, XSLT 的通用的接口。這樣在你
的程序中你只要使用這些通用的接口实愚,當你需要改變具體的實現(xiàn)時候也不需要修改代碼兼呵。
JAXM(Java API for XML Messaging) 是為SOAP通信提供訪問方法和傳輸機制的API兔辅。
WSDL 是一種 XML 格式,用于將網(wǎng)絡(luò)服務(wù)描述為一組端點击喂,這些端點對包含面向文檔信息或面向過程信息的消息進行操作维苔。
這種格式首先對操作和消息進行抽象描述,然后將其綁定到具體的網(wǎng)絡(luò)協(xié)議和消息格式上以定義端點懂昂。相關(guān)的具體端點即組合成為抽象端點(服務(wù))介时。
SOAP即簡單對象訪問協(xié)議(Simple Object Access Protocol),它是用于交換XML編碼信息的輕量級協(xié)議凌彬。
UDDI 的目的是為電子商務(wù)建立標準沸柔;UDDI是一套基于 Web的、分布式的铲敛、為Web Service提供的褐澎、信息注冊中心的實現(xiàn)標準規(guī)范,同時也包含一組使企業(yè)能將自身提供的Web Service 注冊伐蒋,以使別的企業(yè)能夠發(fā)現(xiàn)的訪問協(xié)議的實現(xiàn)標準工三。
120、C/S 與 B/S 區(qū)別:
答:有如下八個方面的不同:
1.硬件環(huán)境不同: C/S 一般建立在專用的網(wǎng)絡(luò)上, 小范圍里的網(wǎng)絡(luò)環(huán)境, 局域網(wǎng)之間再通過專門服務(wù)器提供連接和數(shù)據(jù)交換服務(wù).
B/S 建立在廣域網(wǎng)之上的, 不必是專門的網(wǎng)絡(luò)硬件環(huán)境,例與電話上網(wǎng), 租用設(shè)備. 信息自己管理. 有比C/S更強的適應(yīng)范圍, 一般只要有操作系統(tǒng)和瀏覽器就行
2.對安全要求不同
C/S 一般面向相對固定的用戶群, 對信息安全的控制能力很強. 一般高度機密的信息系統(tǒng)采用C/S 結(jié)構(gòu)適宜. 可以通過B/S發(fā)布部分可公開信息.
B/S 建立在廣域網(wǎng)之上, 對安全的控制能力相對弱, 可能面向不可知的用戶咽弦。
3.對程序架構(gòu)不同
C/S 程序可以更加注重流程, 可以對權(quán)限多層次校驗, 對系統(tǒng)運行速度可以較少考慮.
B/S 對安全以及訪問速度的多重的考慮, 建立在需要更加優(yōu)化的基礎(chǔ)之上. 比 C/S 有更高的要求 B/S結(jié)構(gòu)的程序架構(gòu)是發(fā)展的趨勢, 從MS的.Net系列的BizTalk 2000 Exchange 2000 等, 全面支持網(wǎng)絡(luò)的構(gòu)件搭建的系統(tǒng). SUN 和IBM推的JavaBean 構(gòu)件技術(shù)等,使 B/S更加成熟.
4.軟件重用不同
C/S 程序可以不可避免的整體性考慮, 構(gòu)件的重用性不如在 B/S 要求下的構(gòu)件的重用性好.
B/S 對的多重結(jié)構(gòu),要求構(gòu)件相對獨立的功能. 能夠相對較好的重用.就入買來的餐桌可以再利用,而不是做在墻上的石頭桌子
5.系統(tǒng)維護不同
C/S 程序由于整體性, 必須整體考察, 處理出現(xiàn)的問題以及系統(tǒng)升級. 升級難. 可能是再做一個全新的系統(tǒng)
B/S 構(gòu)件組成,方面構(gòu)件個別的更換,實現(xiàn)系統(tǒng)的無縫升級. 系統(tǒng)維護開銷減到最小.用戶從網(wǎng)上自己下載安裝就可以實現(xiàn)升級.
6.處理問題不同
C/S 程序可以處理用戶面固定, 并且在相同區(qū)域, 安全要求高需求, 與操作系統(tǒng)相關(guān).應(yīng)該都是相同的系統(tǒng)
B/S 建立在廣域網(wǎng)上, 面向不同的用戶群, 分散地域, 這是C/S無法作到的. 與操作系統(tǒng)平臺關(guān)系最小.
7.用戶接口不同
C/S 多是建立的Window 平臺上,表現(xiàn)方法有限,對程序員普遍要求較高
B/S 建立在瀏覽器上, 有更加豐富和生動的表現(xiàn)方式與用戶交流. 并且大部分難度減低,減低開發(fā)成本.
8.信息流不同
C/S 程序一般是典型的中央集權(quán)的機械式處理, 交互性相對低
B/S 信息流向可變化, B-B B-C B-G 等信息徒蟆、流向的變化, 更像交易中心。
121型型、什么是web容器
答:給處于其中的應(yīng)用程序組件(JSP段审,SERVLET)提供一個環(huán)境,使 JSP,SERVLET 直接跟容器中的環(huán)境變量接互闹蒜,不必關(guān)注其它系統(tǒng)問題寺枉。主要有WEB 服務(wù)器來實現(xiàn)。例如:TOMCAT,WEBLOGIC,WEBSPHERE等绷落。該容器提供的接口嚴格遵守 J2EE規(guī)范中的WEB APPLICATION 標準姥闪。我們把遵守以上標準的WEB 服務(wù)器就叫做J2EE 中的WEB容器。
122砌烁、什么是EJB 容器
答:Enterprise java bean 容器筐喳。更具有行業(yè)領(lǐng)域特色。他提供給運行在其中的組件 EJB各種管理功能函喉。只要滿足J2EE規(guī)范的EJB 放入該容器避归,馬上就會被容器進行高效率的管理。并且可以通過現(xiàn)成的接口來獲得系統(tǒng)級別的服務(wù)管呵。例如郵件服務(wù)梳毙、事務(wù)管理
123、什么是JNDI
答:(Java Naming & Directory Interface)JAVA 命名目錄服務(wù)捐下。主要提供的功能是:提供一個目錄系統(tǒng)账锹,讓其它各地的應(yīng)用程序在其上面留下自己的索引萌业,從而滿足快速查找和定位分布式應(yīng)用程序的功能。
124奸柬、什么是JMS
答:(Java Message Service)JAVA消息服務(wù)生年。主要實現(xiàn)各個應(yīng)用程序之間的通訊。包括點對點和廣播鸟缕。
125晶框、什么是JTA
答:(Java Transaction API)JAVA 事務(wù)服務(wù)。提供各種分布式事務(wù)服務(wù)懂从。應(yīng)用程序只需調(diào)用其提供的接口即可授段。
126、什么是JAF
答:(Java Action FrameWork)JAVA 安全認證框架番甩。提供一些安全控制方面的框架侵贵。讓開發(fā)者通過各種部署和自定義實現(xiàn)自己的個性安全控制策略。
RMI/IIOP:(Remote Method Invocation /internet 對象請求中介協(xié)議)他們主要用于通過遠程調(diào)用服務(wù)缘薛。例如窍育,遠程有一臺計算機上運行一個程序,它提供股票分析服務(wù)宴胧,我們可以在本地計算機上實現(xiàn)對其直接調(diào)用漱抓。當然這是要通過一定的規(guī)范才能在異構(gòu)的系統(tǒng)之間進行通信。RMI是 JAVA 特有的恕齐。
127乞娄、MVC的各個部分都有那些技術(shù)來實現(xiàn)?如何實現(xiàn)?
答:MVC 是 Model-View-Controller 的簡寫。"Model" 代表的是應(yīng)用的業(yè)務(wù)邏輯(通過JavaBean显歧,EJB 組件實現(xiàn))仪或,"View" 是應(yīng)用的表示面(由 JSP頁面產(chǎn)生),"Controller" 是提供應(yīng)用的處理過程控制(一般是一個Servlet)士骤,通過這種設(shè)計模型把應(yīng)用邏輯范删,處理過程和顯示邏輯分成不同的組件實現(xiàn)。這些組件可以進行交互和重用拷肌。
設(shè)計模式方面
128到旦、開發(fā)中都用到了那些設(shè)計模式?用在什么場合?
答:每個模式都描述了一個在我們的環(huán)境中不斷出現(xiàn)的問題,然后描述了該問題的解決方案的核心巨缘。通過這種方式厢绝,你可以無數(shù)次地使用那些已有的解決方案,無需在重復(fù)相同的工作带猴。主要用到了 MVC 的設(shè)計模式。用來開發(fā)JSP/Servlet或者J2EE的相關(guān)應(yīng)用懈万。簡單工廠模式等拴清。
129靶病、說說你所熟悉或聽說過的 j2ee 中的幾種常用模式?及對設(shè)計模式的一些看法
答:Session Facade Pattern:使用SessionBean訪問EntityBeanMessage Facade Pattern:實現(xiàn)異步調(diào)用
EJB Command Pattern:使用 Command JavaBeans取代 SessionBean,實現(xiàn)輕量級訪問
Data Transfer Object Factory:通過DTO Factory簡化 EntityBean數(shù)據(jù)提供特性
Generic Attribute Access:通過AttibuteAccess接口簡化 EntityBean數(shù)據(jù)提供特性
Business Interface:通過遠程(本地)接口和 Bean類實現(xiàn)相同接口規(guī)范業(yè)務(wù)邏輯一致性
EJB架構(gòu)的設(shè)計好壞將直接影響系統(tǒng)的性能口予、可擴展性娄周、可維護性、組件可重用性及開發(fā)效率沪停。項目越復(fù)雜煤辨,項目隊伍越龐大則越能體現(xiàn)良好設(shè)計的重要性。
130木张、j2ee常用的設(shè)計模式众辨?說明工廠模式。
答:Java中的23種設(shè)計模式:
Factory(工廠模式)舷礼, Builder(建造模式)鹃彻, Factory Method(工廠方法模式),
Prototype(原始模型模式)妻献,Singleton(單例模式)蛛株, Facade(門面模式),
Adapter(適配器模式)育拨, Bridge(橋梁模式)谨履, Composite(合成模式),
Decorator(裝飾模式)熬丧, Flyweight(享元模式)笋粟, Proxy(代理模式),
Command(命令模式)锹引, Interpreter(解釋器模式)矗钟, Visitor(訪問者模式),
Iterator(迭代子模式)嫌变, Mediator(調(diào)停者模式)吨艇, Memento(備忘錄模式),
Observer(觀察者模式)腾啥, State(狀態(tài)模式)东涡, Strategy(策略模式),
Template Method(模板方法模式)倘待, Chain Of Responsibleity(責(zé)任鏈模式)
工廠模式:工廠模式是一種經(jīng)常被使用到的模式疮跑,根據(jù)工廠模式實現(xiàn)的類可以根據(jù)提供的數(shù)據(jù)生成一組類中某一個類的實例,通常這一組類有一個公共的抽象父類并且實現(xiàn)了相同的方法凸舵,但是這些方法針對不同的數(shù)據(jù)進行了不同的操作祖娘。首先 需要定義一個基類,該類的子類通過不同的方法實現(xiàn)了基類中的方法啊奄。然后需要定義一個工廠類渐苏,工廠類可以根據(jù)條件生成不同的子類實例掀潮。當?shù)玫阶宇惖膶嵗螅_發(fā)人員可以調(diào)用基類中的方法而不必考慮到底返回的是哪一個子類的實例琼富。
131仪吧、UML 方面
答:標準建模語言 UML。用例圖,靜態(tài)圖(包括類圖鞠眉、對象圖和包圖),行為圖,交互圖(順序圖,合作圖),實現(xiàn)圖,
132薯鼠、CORBA 是什么?用途是什么?
答:CORBA 標準是公共對象請求代理結(jié)構(gòu)(Common Object Request Broker Architecture),由對象管理組織 (Object Management Group械蹋,縮寫為 OMG)標準化出皇。它的組成是接口定義語言(IDL), 語言綁定(binding:也譯為聯(lián)編)和允許應(yīng)用程 序間互操作的協(xié)議。 其目的為: 用不同的程序設(shè)計語言書寫在不同的進程中運行為不同的操作系統(tǒng)開發(fā)
LINUX方面
133朝蜘、LINUX 下線程恶迈,GDI類的解釋。
答:LINUX 實現(xiàn)的就是基于核心輕量級進程的"一對一"線程模型谱醇,一個線程實體對應(yīng)一個核心輕量級進程暇仲,而線程之間的管理在核外函數(shù)庫中實現(xiàn)。 GDI類為圖像設(shè)備編程接口類庫副渴。
134奈附、LINUX 下線程,GDI類的解釋煮剧。
LINUX 實現(xiàn)的就是基于核心輕量級進程的"一對一"線程模型斥滤,一個線程實體對應(yīng)一個核心輕量級進程,而線程之間的管理在核外函數(shù)庫中實現(xiàn)勉盅。
GDI類為圖像設(shè)備編程接口類庫佑颇。
代碼與編程題
135、寫一個Singleton 出來
Singleton模式主要作用是保證在 Java應(yīng)用程序中草娜,一個類 Class只有一個實例存在挑胸。
一般Singleton模式通常有幾種種形式:
第一種形式: 定義一個類,它的構(gòu)造函數(shù)為 private 的宰闰,它有一個 static 的 private 的該類變量茬贵,在類初始化時實例話,通過一個public的getInstance 方法獲取對它的引用,繼而調(diào)用其中的方法移袍。
public class Singleton {
private Singleton(){}
//在自己內(nèi)部定義自己一個實例解藻,是不是很奇怪?
//注意這是private 只供內(nèi)部調(diào)用
private static Singleton instance = new Singleton();
//這里提供了一個供外部訪問本 class的靜態(tài)方法葡盗,可以直接訪問
public static Singleton getInstance() {
return instance;
}
}
第二種形式: public class Singleton {
private static Singleton instance = null;
public static synchronized Singleton getInstance() {
//這個方法比上面有所改進螟左,不用每次都進行生成對象,只是第一次
//使用時生成實例,提高了效率胶背!
if (instance==null)
instance=new Singleton();
return instance; }
}
其他形式:
定義一個類虫啥,它的構(gòu)造函數(shù)為 private的,所有方法為 static的奄妨。
一般認為第一種形式要更加安全些
136、繼承時候類的執(zhí)行順序問題,一般都是選擇題,問你將會打印出什么?
答:父類:
package test;
public class FatherClass
{
public FatherClass()
{
System.out.println("FatherClass Create");
}
}
子類:
package test;
import test.FatherClass;
public class ChildClass extends FatherClass
{
public ChildClass()
{
System.out.println("ChildClass Create");
}
public static void main(String[] args)
{
FatherClass fc = new FatherClass();
ChildClass cc = new ChildClass();
}
}
輸出結(jié)果:
C:>java test.ChildClass
FatherClass Create
FatherClass Create
ChildClass Create
137苹祟、內(nèi)部類的實現(xiàn)方式?
答:示例代碼如下:
package test;
public class OuterClass
{
private class InterClass
{
public InterClass()
{
System.out.println("InterClass Create");
}
}
public OuterClass()
{
InterClass ic = new InterClass();
System.out.println("OuterClass Create");
}
public static void main(String[] args)
{
OuterClass oc = new OuterClass();
}
}
輸出結(jié)果:
C:>java test/OuterClass
InterClass Create
OuterClass Create
再一個例題:
public class OuterClass {
private double d1 = 1.0; //insert code here
}
You need to insert an inner class declaration at line 3. Which two inner class declarations are
valid?(Choose two.)
A. class InnerOne{
public static double methoda() {return d1;}
}
B. public class InnerOne{
static double methoda() {return d1;}
}
C. private class InnerOne{
double methoda() {return d1;}
}
D. static class InnerOne{
protected double methoda() {return d1;}
}
E. abstract class InnerOne{
public abstract double methoda();
}
說明如下:
一.靜態(tài)內(nèi)部類可以有靜態(tài)成員砸抛,而非靜態(tài)內(nèi)部類則不能有靜態(tài)成員。 故 A树枫、B 錯
二.靜態(tài)內(nèi)部類的非靜態(tài)成員可以訪問外部類的靜態(tài)變量直焙,而不可訪問外部類的非靜態(tài)變量;
return d1 出錯砂轻。 故 D 錯
三.非靜態(tài)內(nèi)部類的非靜態(tài)成員可以訪問外部類的非靜態(tài)變量奔誓。 故 C 正確
四.答案為C、E
138搔涝、Java 的通信編程厨喂,編程題(或問答),用 JAVA SOCKET 編程庄呈,讀服務(wù)器幾個字符蜕煌,再寫入本地顯示?
答:Server端程序: package test;
import java.net.;
import java.io.;
public class Server
{
private ServerSocket ss;
private Socket socket;
private BufferedReader in;
private PrintWriter out;
public Server()
{
try
{
ss=new ServerSocket(10000);
while(true)
{
socket = ss.accept();
String RemoteIP = socket.getInetAddress().getHostAddress();
String RemotePort = ":"+socket.getLocalPort();
System.out.println("A client come in!IP:"+RemoteIP+RemotePort);
in = new BufferedReader(new
InputStreamReader(socket.getInputStream()));
String line = in.readLine();
System.out.println("Cleint send is :" + line);
out = new PrintWriter(socket.getOutputStream(),true);
out.println("Your Message Received!");
out.close();
in.close();
socket.close();
}
}catch (IOException e)
{
out.println("wrong");
}
}
public static void main(String[] args)
{
new Server();
}
};
Client端程序:
package test;
import java.io.;
import java.net.;
public class Client
{
Socket socket;
BufferedReader in;
PrintWriter out;
public Client()
{
try
{
System.out.println("Try to Connect to 127.0.0.1:10000");
socket = new Socket("127.0.0.1",10000);
System.out.println("The Server Connected!"); System.out.println("Please enter some Character:");
BufferedReader line = new BufferedReader(new
InputStreamReader(System.in));
out = new PrintWriter(socket.getOutputStream(),true);
out.println(line.readLine());
in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
System.out.println(in.readLine());
out.close();
in.close();
socket.close();
}catch(IOException e)
{
out.println("Wrong");
}
}
public static void main(String[] args)
{
new Client();
}
};
139诬留、用 JAVA 實現(xiàn)一種排序斜纪,JAVA 類實現(xiàn)序列化的方法(二種)? 如在 COLLECTION 框架中文兑,實現(xiàn)比較要實現(xiàn)什么樣的接口盒刚?
答:用插入法進行排序代碼如下
package test;
import java.util.*;
class InsertSort
{
ArrayList al;
public InsertSort(int num,int mod)
{
al = new ArrayList(num);
Random rand = new Random();
System.out.println("The ArrayList Sort Before:");
for (int i=0;i<num ;i++ )
{
al.add(new Integer(Math.abs(rand.nextInt()) % mod + 1));
System.out.println("al["+i+"]="+al.get(i));
}
}
public void SortIt()
{
Integer tempInt;
int MaxSize=1;
for(int i=1;i<al.size();i++)
{
tempInt = (Integer)al.remove(i);
if(tempInt.intValue()>=((Integer)al.get(MaxSize-1)).intValue())
{
al.add(MaxSize,tempInt);
MaxSize++;
System.out.println(al.toString());
} else {
for (int j=0;j<MaxSize ;j++ )
{
if
(((Integer)al.get(j)).intValue()>=tempInt.intValue())
{
al.add(j,tempInt);
MaxSize++;
System.out.println(al.toString());
break;
}
}
}
}
System.out.println("The ArrayList Sort After:");
for(int i=0;i<al.size();i++)
{
System.out.println("al["+i+"]="+al.get(i));
}
}
public static void main(String[] args)
{
InsertSort is = new InsertSort(10,100);
is.SortIt();
}
}
140、編程:編寫一個截取字符串的函數(shù)绿贞,輸入為一個字符串和字節(jié)數(shù)因块,輸出為按字節(jié)截取的字符串。 但是要保證漢字不被截半個樟蠕,如“我ABC”4贮聂,應(yīng)該截為“我AB”,輸入“我ABC 漢 DEF”寨辩,6吓懈,應(yīng)該輸出為“我ABC”而不是“我ABC+漢的半個”。
答:代碼如下: package test;
class SplitString
{
String SplitStr;
int SplitByte;
public SplitString(String str,int bytes)
{
SplitStr=str;
SplitByte=bytes;
System.out.println("The String is:'"+SplitStr+"';SplitBytes="+SplitByte);
}
public void SplitIt()
{
int loopCount;
loopCount=(SplitStr.length()%SplitByte==0)?(SplitStr.length()/SplitByte):(SplitStr.length()/Split
Byte+1);
System.out.println("Will Split into "+loopCount);
for (int i=1;i<=loopCount ;i++ )
{
if (i==loopCount){
System.out.println(SplitStr.substring((i-1)*SplitByte,SplitStr.length()));
} else {
System.out.println(SplitStr.substring((i-1)SplitByte,(iSplitByte)));
}
}
}
public static void main(String[] args)
{
SplitString ss = new SplitString("test中 dd文 dsaf中男大 3443n中國43 中國人
0ewldfls=103",4);
ss.SplitIt();
}
}
142靡狞、可能會讓你寫一段 Jdbc連Oracle 的程序,并實現(xiàn)數(shù)據(jù)查詢.
答:程序如下:
package hello.ant;
import java.sql.*;
public class jdbc
{
String dbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl";
String theUser="admin";
String thePw="manager";
Connection c=null;
Statement conn;
ResultSet rs=null;
public jdbc()
{
try{
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
c = DriverManager.getConnection(dbUrl,theUser,thePw); conn=c.createStatement();
}catch(Exception e){
e.printStackTrace();
}
}
public boolean executeUpdate(String sql)
{
try
{
conn.executeUpdate(sql);
return true;
}
catch (SQLException e)
{
e.printStackTrace();
return false;
}
}
public ResultSet executeQuery(String sql)
{
rs=null;
try
{
rs=conn.executeQuery(sql);
}
catch (SQLException e)
{
e.printStackTrace();
}
return rs;
}
public void close()
{
try
{ conn.close();
c.close();
}
catch (Exception e)
{
e.printStackTrace();
}
}
public static void main(String[] args)
{
ResultSet rs;
jdbc conn = new jdbc();
rs=conn.executeQuery("select * from test");
try{
while (rs.next())
{
System.out.println(rs.getString("id"));
System.out.println(rs.getString("name"));
}
}catch(Exception e)
{
e.printStackTrace();
}
}
}
143耻警、ORACLE 大數(shù)據(jù)量下的分頁解決方法。一般用截取 ID方法,還有是三層嵌套方法甘穿。
答:一種分頁方法
<%
int i=1;
int numPages=14;
String pages = request.getParameter("page") ;
int currentPage = 1;
currentPage=(pages==null)?(1):{Integer.parseInt(pages)}
sql = "select count(*) from tables";
ResultSet rs = DBLink.executeQuery(sql) ;
while(rs.next()) i = rs.getInt(1) ;
int intPageCount=1;
intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1);
int nextPage ;
int upPage;
nextPage = currentPage+1; if (nextPage>=intPageCount) nextPage=intPageCount;
upPage = currentPage-1;
if (upPage<=1) upPage=1;
rs.close();
sql="select * from tables";
rs=DBLink.executeQuery(sql);
i=0;
while((i<numPages*(currentPage-1))&&rs.next()){i++;}
%>
//輸出內(nèi)容
//輸出翻頁連接
合計:<%=currentPage%>/<%=intPageCount%><a href="List.jsp?page=1">第一頁</a><a
href="List.jsp?page=<%=upPage%>">上一頁</a>
<%
for(int j=1;j<=intPageCount;j++){
if(currentPage!=j){
%>
<a href="list.jsp?page=<%=j%>">[<%=j%>]</a>
<%
}else{
out.println(j);
}
}
%>
<a href="List.jsp?page=<%=nextPage%>"> 下 一 頁 </a><a
href="List.jsp?page=<%=intPageCount%>">最后頁
</a>
144腮恩、用 jdom解析xml 文件時如何解決中文問題?如何解析?
答:看如下代碼,用編碼方式加以解決
package test;
import java.io.*;
public class DOMTest
{
private String inFile = "c:\people.xml";
private String outFile = "c:\people.xml";
public static void main(String args[])
{
new DOMTest();
}
public DOMTest()
{
try
{
javax.xml.parsers.DocumentBuilder builder =
javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();
org.w3c.dom.Document doc = builder.newDocument();
org.w3c.dom.Element root = doc.createElement("老師");
org.w3c.dom.Element wang = doc.createElement("王");
org.w3c.dom.Element liu = doc.createElement("劉");
wang.appendChild(doc.createTextNode("我是王老師"));
root.appendChild(wang);
doc.appendChild(root);
javax.xml.transform.Transformer transformer =
javax.xml.transform.TransformerFactory.newInstance().newTransformer();
transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING, "gb2312");
transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT, "yes");
transformer.transform(new javax.xml.transform.dom.DOMSource(doc),
new
javax.xml.transform.stream.StreamResult(outFile));
}
catch (Exception e)
{
System.out.println (e.getMessage());
}
}
}
145、編程用JAVA 解析 XML 的方式.
答:用 SAX方式解析XML温兼,XML文件如下:
<?xml version="1.0" encoding="gb2312"?>
<person>
<name>王小明</name>
<college>信息學(xué)院</college>
<telephone>6258113</telephone>
<notes>男,1955 年生,博士秸滴,95 年調(diào)入海南大學(xué)</notes>
</person>
事件回調(diào)類SAXHandler.java
import java.io.*;
import java.util.Hashtable;
import org.xml.sax.*;
public class SAXHandler extends HandlerBase
{
private Hashtable table = new Hashtable(); private String currentElement = null;
private String currentValue = null;
public void setTable(Hashtable table)
{
this.table = table;
}
public Hashtable getTable()
{
return table;
}
public void startElement(String tag, AttributeList attrs)
throws SAXException
{
currentElement = tag;
}
public void characters(char[] ch, int start, int length)
throws SAXException
{
currentValue = new String(ch, start, length);
}
public void endElement(String name) throws SAXException
{
if (currentElement.equals(name))
table.put(currentElement, currentValue);
}
} JSP內(nèi)容顯示源碼,SaxXml.jsp:
<HTML>
<HEAD>
<TITLE>剖析XML文件 people.xml</TITLE>
</HEAD>
<BODY>
<%@ page errorPage="ErrPage.jsp"
contentType="text/html;charset=GB2312" %>
<%@ page import="java.io." %>
<%@ page import="java.util.Hashtable" %>
<%@ page import="org.w3c.dom." %>
<%@ page import="org.xml.sax.*" %>
<%@ page import="javax.xml.parsers.SAXParserFactory" %>
<%@ page import="javax.xml.parsers.SAXParser" %>
<%@ page import="SAXHandler" %>
<%
File file = new File("c:\people.xml");
FileReader reader = new FileReader(file);
Parser parser;
SAXParserFactory spf = SAXParserFactory.newInstance();
SAXParser sp = spf.newSAXParser();
SAXHandler handler = new SAXHandler();
sp.parse(new InputSource(reader), handler);
Hashtable hashTable = handler.getTable();
out.println("<TABLE BORDER=2><CAPTION>教師信息表</CAPTION>");
out.println("<TR><TD>姓名</TD>" + "<TD>" +
(String)hashTable.get(new String("name")) + "</TD></TR>");
out.println("<TR><TD>學(xué)院</TD>" + "<TD>" +
(String)hashTable.get(new String("college"))+"</TD></TR>");
out.println("<TR><TD>電話</TD>" + "<TD>" +
(String)hashTable.get(new String("telephone")) + "</TD></TR>");
out.println("<TR><TD>備注</TD>" + "<TD>" +
(String)hashTable.get(new String("notes")) + "</TD></TR>");
out.println("</TABLE>");
%>
</BODY>
</HTML>
146、EJB的基本架構(gòu)
答:一個EJB包括三個部分:
Remote Interface 接口的代碼
package Beans;
import javax.ejb.EJBObject;
import java.rmi.RemoteException;
public interface Add extends EJBObject
{
//some method declare
}
Home Interface 接口的代碼
package Beans;
import java.rmi.RemoteException;
import jaax.ejb.CreateException;
import javax.ejb.EJBHome;
public interface AddHome extends EJBHome
{
//some method declare
}
EJB 類的代碼
package Beans;
import java.rmi.RemoteException;
import javax.ejb.SessionBean;
import javx.ejb.SessionContext;
public class AddBean Implements SessionBean
{
//some method declare
}
147募判、如何校驗數(shù)字型?
var re=/^\d{1,8}$|.\d{1,2}$/;
var str=document.form1.all(i).value;
var r=str.match(re);
if (r==null)
{
sign=-4;
break;
}
else{
document.form1.all(i).value=parseFloat(str);
}
148荡含、將一個鍵盤輸入的數(shù)字轉(zhuǎn)化成中文輸出 (例如:輸入:1234567 輸出:一百二拾三萬四千五百六拾七)
用java語言實現(xiàn),,請編一段程序?qū)崿F(xiàn)!
public class Reader {
private String strNum;
private String strNumChFormat;
private String strNumTemp;
private int intNumLen;
private String strBegin;
public Reader(String strNum) {
this.strNum = strNum;
}
public boolean check(String strNum) {
boolean valid = false;
if (strNum.substring(0,1).equals("0")){
this.strNum = strNum.substring(1);
}
try {
new Double(strNum);
valid = true;
}
catch (NumberFormatException ex) {
System.out.println("Bad number format!");
}
return valid;
}
public void init() {
strNumChFormat = "";
intNumLen = strNum.length();
strNumTemp = strNum;
strNumTemp = strNumTemp.replace('1', '一');
strNumTemp = strNumTemp.replace('2', '二');
strNumTemp = strNumTemp.replace('3', '三');
strNumTemp = strNumTemp.replace('4', '四');
strNumTemp = strNumTemp.replace('5', '五');
strNumTemp = strNumTemp.replace('6', '六');
strNumTemp = strNumTemp.replace('7', '七');
strNumTemp = strNumTemp.replace('8', '八');
strNumTemp = strNumTemp.replace('9', '九');
strNumTemp = strNumTemp.replace('0', '零');
strNumTemp = strNumTemp.replace('.', '點');
strBegin = strNumTemp.substring(0, 1);
}
public String readNum() {
if (check(strNum)) {
init();
try {
for (int i = 1, j = 1, k = 1; i < intNumLen; i++) {
if (strNumTemp.charAt(intNumLen - 1) == '零' && i == 1) {
strNumChFormat = "位";
}
else if (strNumTemp.charAt(intNumLen - i) == '零' && j == 1) {
strNumChFormat = "位" + strNumChFormat;
}
else if (strNumTemp.charAt(intNumLen - i) == '點') {
j = 1;
k = 1;
strNumChFormat = strNumTemp.charAt(intNumLen - i) + strNumChFormat;
continue;
}
else {
strNumChFormat = strNumTemp.charAt(intNumLen - i) + strNumChFormat;
}
if (strNumTemp.charAt(intNumLen - i - 1) != '位' &&
strNumTemp.charAt(intNumLen - i - 1) != '零') {
if (j == 1 && i < intNumLen) {
strNumChFormat = '拾' + strNumChFormat;
}
else if (j == 2 && i < intNumLen) {
strNumChFormat = '百' + strNumChFormat;
}
else if (j == 3 && i < intNumLen) {
strNumChFormat = '千' + strNumChFormat;
}
}
if (j == 4 && i < intNumLen) {
j = 0;
}
if (k == 4 && i < intNumLen) {
strNumChFormat = '萬' + strNumChFormat;
}
else if (k == 8 && i < intNumLen) {
k = 0;
strNumChFormat = '億' + strNumChFormat;
}
j++;
k++;
}
while (strNumChFormat.indexOf("位") != -1) {
strNumChFormat = strNumChFormat.replaceAll("位", " ");
}
if (strNumChFormat.substring(0, 2) == "一拾") {
strNumChFormat = strNumChFormat.substring(1, strNumChFormat.length());
}
if (strNumChFormat.indexOf("點") >= 0) {
String rebegin = strNumChFormat.substring(0,
strNumChFormat.indexOf("點"));
String relast = strNumChFormat.substring(strNumChFormat.indexOf("點"),
strNumChFormat.length());
for (int i = 1; i <= relast.length(); i++) {
relast = relast.replaceAll("拾", "");
relast = relast.replaceAll("百", "");
relast = relast.replaceAll("千", "");
relast = relast.replaceAll("萬", "");
relast = relast.replaceAll("億", "");
}
strNumChFormat = rebegin + relast;
}
}
catch (ArrayIndexOutOfBoundsException ex) {
ex.printStackTrace();
}
catch (Exception ex) {
ex.printStackTrace();
}
int off = strNumChFormat.indexOf("點");
strNumChFormat = strBegin + strNumChFormat.substring(0);
}
else {
strNumChFormat = "";
}
return strNumChFormat;
}
public static void main(String args[]) {
try {
String number = args[0].toString();
System.out.println("The number is: " + number); Reader reader = new Reader(number);
System.out.println("Output String: " + reader.readNum());
}
catch (Exception ex) {
System.out.println("Please input like that: javac Reader <number>");
}
}
}
149、JAVA代碼查錯
abstract class Name {
private String name;
public abstract boolean isStupidName(String name) {}
}
這有何錯誤?
答案: 錯届垫。abstract method必須以分號結(jié)尾释液,且不帶花括號。
public class Something {
void doSomething () {
private String s = "";
int l = s.length();
}
}
有錯嗎?
答案: 錯装处。局部變量前不能放置任何訪問修飾符 (private误债,public,和 protected)妄迁。final 可以
用來修飾局部變量
(final 如同 abstract 和 strictfp寝蹈,都是非訪問修飾符,strictfp 只能修飾 class 和 method 而非
variable)判族。
abstract class Something {
private abstract String doSomething ();
}
答案: 錯躺盛。abstract 的 methods 不能以 private 修飾。abstract 的 methods 就是讓子類implement(實現(xiàn))具體細節(jié)的形帮,怎么可以用private把abstractmethod封鎖起來呢? (同理槽惫,abstract method前不能加final)。
public class Something {
public int addOne(final int x) {
return ++x;
}
}
答案: 錯辩撑。int x被修飾成 final界斜,意味著x不能在addOne method 中被修改。
public class Something {
public static void main(String[] args) {
Other o = new Other();
new Something().addOne(o);
}
public void addOne(final Other o) {
o.i++;
}
}
class Other {
public int i;
}
和上面的很相似合冀,都是關(guān)于 final的問題各薇,這有錯嗎?
答案: 正確。在addOne method 中君躺,參數(shù)o被修飾成 final峭判。如果在addOne method 里我們
修改了o的reference(比如: o = new Other();),那么如同上例這題也是錯的棕叫。但這里修改的是
o的member vairable(成員變量)林螃,而o的reference并沒有改變。
class Something {
int i; public void doSomething() {
System.out.println("i = " + i);
}
}
答案: 正確俺泣。輸出的是"i = 0"疗认。int i屬於instant variable (實例變量完残,或叫成員變量)。instant
variable 有default
value横漏。int的default value是 0谨设。
class Something {
final int i;
public void doSomething() {
System.out.println("i = " + i);
}
}
答案: 錯。final int i是個final的instant variable (實例變量缎浇,或叫成員變量)扎拣。final的 instant
variable 沒有 default value,必須在constructor (構(gòu)造器)結(jié)束之前被賦予一個明確的值素跺∨羟铮可以修改為"final int i = 0;"。
public class Something {
public static void main(String[] args) {
Something s = new Something();
System.out.println("s.doSomething() returns " + doSomething());
}
public String doSomething() {
return "Do something ...";
}
}
答案: 錯亡笑。看上去在main里 call doSomething沒有什么問題横朋,畢竟兩個methods都在同一個class里仑乌。但仔細看,main是static 的琴锭。 static method 不能直接 call non-static methods 晰甚。 可改成
"System.out.println("s.doSomething() returns " + s.doSomething());"。同理决帖,static method不能訪問 non-static instant variable厕九。
此處,Something類的文件名叫 OtherThing.java
class Something {
private static void main(String[] something_to_do) {
System.out.println("Do something ...");
}
}
答案: 正確地回。從來沒有人說過 Java的Class名字必須和其文件名相同扁远。但public class的名字必須和文件名相同。
10.
interface A{
int x = 0;
}
class B{
int x =1;
}
class C extends B implements A {
public void pX(){
System.out.println(x);
}
public static void main(String[] args) {
new C().pX();
}
}
答案:錯誤刻像。在編譯時會發(fā)生錯誤(錯誤描述不同的JVM有不同的信息畅买,意思就是未明確的x調(diào)用,兩個x都匹配(就象在同時import java.util和java.sql兩個包時直接聲明Date一樣)细睡。對于父類的變量,可以用 super.x來明確谷羞,而接口的屬性默認隱含為 public static final.所以可以通過A.x來明確。
interface Playable {
void play();
}
interface Bounceable {
void play();
}
interface Rollable extends Playable, Bounceable {
Ball ball = new Ball("PingPang");
}
class Ball implements Rollable {
private String name;
public String getName() {
return name;
}
public Ball(String name) {
this.name = name;
}
public void play() {
ball = new Ball("Football");
System.out.println(ball.getName());
}
}
答案: 錯溜徙。"interface Rollable extends Playable, Bounceable"沒有問題湃缎。interface 可繼承多個
interfaces,所以這里沒錯蠢壹。問題出在interface Rollable 里的"Ball ball = new Ball("PingPang");"嗓违。任何在 interface里聲明的interfacevariable (接口變量,也可稱成員變量)知残,默認為public static final靠瞎。也就是說
"Ball ball = new Ball("PingPang");"
實際上是"public static final Ball ball = new Ball("PingPang");"比庄。在Ball類的Play()方法中,"ball =
new
Ball("Football");"改變了ball的reference乏盐,而這里的ball來自Rollable interface佳窑, Rollable interface
里的ball是
public static final的,final的object是不能被改變reference的父能。因此編譯器將在"ball = new
Ball("Football");"這里顯示有錯神凑。
28、設(shè)計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();
}
}
}
}