C或Java中的異常處理機制的簡單原理和應(yīng)用_第1頁
C或Java中的異常處理機制的簡單原理和應(yīng)用_第2頁
C或Java中的異常處理機制的簡單原理和應(yīng)用_第3頁
C或Java中的異常處理機制的簡單原理和應(yīng)用_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、1.C+或Java中的異常處理機制的簡單原理和應(yīng)用。 當JAVA程序違反了JAVA的語義規(guī)則時,JAVA虛擬機就會將發(fā)生的錯誤表示為一個異常。違 反語義規(guī)則包括2種情況。一種是JAVA類庫內(nèi)置的語義檢查。例如數(shù)組下標越界,會引發(fā)In dexOutOfBoundsException;訪問null的對象時會引發(fā)NullPointerException。另一種情況 就是JAVA允許程序員擴展這種語義檢查,程序員可以創(chuàng)建自己的異常,并自由選擇在何時 2. Java的接口和C+的虛類的相同和不同處。 由于Java不支持多繼承,而有可能某個類或?qū)ο笠褂梅謩e在幾個類或?qū)ο罄锩娴姆椒ɑ?屬性,現(xiàn)有的單繼承機

2、制就不能滿足要求。與繼承相比,接口有更高的靈活性,因為接口 中沒有任何實現(xiàn)代碼。當一個類實現(xiàn)了接口以后,該類要實現(xiàn)接口里面所有的方法和屬性 ,并且接口里面的屬性在默認狀態(tài)下面都是public static,所有方法默認情況下是public .一個類可以實現(xiàn)多個接口。 3. 垃圾回收的優(yōu)點和原理。并考慮2種回收機制。 Java語言中一個顯著的特點就是引入了垃圾回收機制,使c+程序員最頭疼的內(nèi)存管理的問 題迎刃而解,它使得Java程序員在編寫程序的時候不再需要考慮內(nèi)存管理。由于有個垃圾 回收機制,Java中的對象不再有“作用域”的概念,只有對象的引用才有“作用域”。垃 圾回收可以有效的防止內(nèi)存泄露

3、,有效的使用可以使用的內(nèi)存。垃圾回收器通常是作為一 個單獨的低級別的線程運行,不可預(yù)知的情況下對內(nèi)存堆中已經(jīng)死亡的或者長時間沒有使 用的對象進行清楚和回收,程序員不能實時的調(diào)用垃圾回收器對某個對象或所有對象進行 垃圾回收?;厥諜C制有分代復(fù)制垃圾回收和標記垃圾回收,增量垃圾回收。 4. 請說出你所知道的線程同步的方法。 wait():使一個線程處于等待狀態(tài),并且釋放所持有的對象的lock。 sleep():使一個正在運行的線程處于睡眠狀態(tài),是一個靜態(tài)方法,調(diào)用此方法要捕捉Inte rruptedException異常。 notify():喚醒一個處于等待狀態(tài)的線程,注意的是在調(diào)用此方法的時候,并

4、不能確切的喚 醒某一個等待狀態(tài)的線程,而是由JVM確定喚醒哪個線程,而且不是按優(yōu)先級。 Allnotity():喚醒所有處入等待狀態(tài)的線程,注意并不是給所有喚醒線程一個對象的鎖, 而是讓它們競爭。 6. Error與Exception有什么區(qū)別? Error表示系統(tǒng)級的錯誤和程序不必處理的異常, Exception表示需要捕捉或者需要程序進行處理的異常。 9. heap和stack有什么區(qū)別。 棧是一種線形集合,其添加和刪除元素的操作應(yīng)在同一段完成。棧按照后進先出的方式進 行處理。堆是棧的一個組成元素 10. 如果系統(tǒng)要使用超大整數(shù)(超過long長度范圍),請你設(shè)計一個數(shù)據(jù)結(jié)構(gòu)來存儲這種 超大

5、型數(shù)字以及設(shè)計一種算法來實現(xiàn)超大整數(shù)加法運算)。 public class BigInt() int ArrOne = new ArrOne1000; String intString="" public int Arr(String s) intString = s; for(int i=0;i<ArrOne.leght;i+) 12,談?wù)刦inal, finally, finalize的區(qū)別。 final修飾符(關(guān)鍵字)如果一個類被聲明為final,意味著它不能再派生出新的子 類,不能作為父類被繼承。因此一個類不能既被聲明為 abstract的,又被聲明為fina

6、l的 。將變量或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變量必 須在聲明時給定初值,而在以后的引用中只能讀取,不可修改。被聲明為final的方法也同 樣只能使用,不能重載。 finally再異常處理時提供 finally 塊來執(zhí)行任何清除操作。如果拋出一個異常, 那么相匹配的 catch 子句就會執(zhí)行,然后控制就會進入 finally 塊(如果有的話)。 finalize方法名。Java 技術(shù)允許使用 finalize() 方法在垃圾收集器將對象從內(nèi)存 中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在確定這個對象沒有被引用時對這個對象調(diào)用的。它是在 Ob

7、ject 類中定義的,因此所有的類都繼承了它。子類覆蓋 finalize() 方法以整理系統(tǒng)資源或者執(zhí)行其他清理工作。finalize() 方法是在垃圾收集 器刪除對象之前對這個對象調(diào)用的。 13,Anonymous Inner Class (匿名內(nèi)部類) 是否可以extends(繼承)其它類,是否可以im plements(實現(xiàn))interface(接口)? 匿名的內(nèi)部類是沒有名字的內(nèi)部類。不能extends(繼承) 其它類,但一個內(nèi)部類可以 作為一個接口,由另一個內(nèi)部類實現(xiàn)。 14,Static Nested Class 和 Inner Class的不同,說得越多越好(面試題有的很籠統(tǒng))。

8、 Nested Class (一般是C+的說法),Inner Class (一般是JAVA的說法)。Java內(nèi)部 類與C+嵌套類最大的不同就在于是否有指向外部的引用上。具體可見http: /www.front 注: 靜態(tài)內(nèi)部類(Inner Class)意味著1創(chuàng)建一個static內(nèi)部類的對象,不需要一個 外部類對象,2不能從一個static內(nèi)部類的一個對象訪問一個外部類對象 14,&和&&的區(qū)別。 &是位運算符。&&是布爾邏輯運算符。 15,HashMap和Hashtable的區(qū)別。 都屬于Map接口的類,實現(xiàn)了將惟一鍵映射到特定的值上。 Has

9、hMap 類沒有分類或者排序。它允許一個 null 鍵和多個 null 值。 Hashtable 類似于 HashMap,但是不允許 null 鍵和 null 值。它也比 HashMap 慢, 因為它是同步的。 16,Collection 和 Collections的區(qū)別。 Collections是個java.util下的類,它包含有各種有關(guān)集合操作的靜態(tài)方法。 Collection是個java.util下的接口,它是各種集合結(jié)構(gòu)的父接口。 18,GC是什么? 為什么要有GC? (基礎(chǔ))。 GC是垃圾收集器。Java 程序員不用擔心內(nèi)存管理,因為垃圾收集器會自動進行管理。 要請求垃圾收集,可以

10、調(diào)用下面的方法之一: System.gc() Runtime.getRuntime().gc() 19,String s = new String("xyz");創(chuàng)建了幾個String Object? 兩個對象,一個是“xyx”,一個是指向“xyx”的引用對象s。 20,Math.round(11.5)等於多少? Math.round(-11.5)等於多少? Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11; 21,short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1

11、+ = 1;有什么錯? short s1 = 1; s1 = s1 + 1;有錯,s1是short型,s1+1是int型,不能顯式轉(zhuǎn)化為sho rt型。可修改為s1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正確。 22,sleep() 和 wait() 有什么區(qū)別? 搞線程的最愛 sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿后,線程不一定立 即恢復(fù)執(zhí)行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調(diào)度為放棄執(zhí)行, 除非(a)“醒來”的線程具有更高的優(yōu)先級 (b)正在運行的線程因為其它原因而阻塞。 wait()是線程交互時,

12、如果線程對一個同步對象x 發(fā)出一個wait()調(diào)用,該線程會暫 停執(zhí)行,被調(diào)對象進入等待狀態(tài),直到被喚醒或等待時間到。 23,Java有沒有g(shù)oto? Gotojava中的保留字,現(xiàn)在沒有在java中使用。 24,數(shù)組有沒有l(wèi)ength()這個方法? String有沒有l(wèi)ength()這個方法? 數(shù)組沒有l(wèi)ength()這個方法,有l(wèi)ength的屬性。 String有有l(wèi)ength()這個方法。 25,Overload和Override的區(qū)別。Overloaded的方法是否可以改變返回值的類型? 方法的重寫Overriding和重載Overloading是Java多態(tài)性的不同表現(xiàn)。重寫Over

13、ridin g是父類與子類之間多態(tài)性的一種表現(xiàn),重載Overloading是一個類中多態(tài)性的一種表現(xiàn)。 如果在子類中定義某方法與其父類有相同的名稱和參數(shù),我們說該方法被重寫 (Overridi ng)。子類的對象使用這個方法時,將調(diào)用子類中的定義,對它而言,父類中的定義如同被 “屏蔽”了。如果在一個類中定義了多個同名的方法,它們或有不同的參數(shù)個數(shù)或有不同 的參數(shù)類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類 型。 26,Set里的元素是不能重復(fù)的,那么用什么方法來區(qū)分重復(fù)與否呢? 是用=還是equals( )? 它們有何區(qū)別? Set里的元素是

14、不能重復(fù)的,那么用iterator()方法來區(qū)分重復(fù)與否。equals()是判讀 兩個Set是否相等。 equals()和=方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當兩 個分離的對象的內(nèi)容和類型相配的話,返回真值。 28,error和exception有什么區(qū)別? error 表示恢復(fù)不是不可能但很困難的情況下的一種嚴重問題。比如說內(nèi)存溢出。不 可能指望程序能處理這樣的情況。 exception 表示一種設(shè)計或?qū)崿F(xiàn)問題。也就是說,它表示如果程序運行正常,從不會 發(fā)生的情況。 29,List, Set, Map是否繼承自Collection接口? List,Set是 ,

15、Map不是 30,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)是抽象類的變體。在接口

16、中,所有方法都是抽象的。多繼承性可通 過實現(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)了接口。 31,abstract的method是否可同時是static,是否可同時

17、是native,是否可同時是synchro nized? 都不能 32,接口是否可繼承接口? 抽象類是否可實現(xiàn)(implements)接口? 抽象類是否可繼承實體 類(concrete class)? 接口可以繼承接口。抽象類可以實現(xiàn)(implements)接口,抽象類是否可繼承實體類, 但前提是實體類必須有明確的構(gòu)造函數(shù)。 33,啟動一個線程是用run()還是start()? 啟動一個線程是調(diào)用start()方法,使線程所代表的虛擬處理機處于可運行狀態(tài),這意 味著它可以由JVM調(diào)度并執(zhí)行。這并不意味著線程就會立即運行。run()方法可以產(chǎn)生必須 退出的標志來停止一個線程。 34,構(gòu)造器Constructor是否可被override? 構(gòu)造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloadi ng。 35,是否可以繼承String類? String類是final類故不可以繼承。 36,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的 其它方法? 不能,一個對象的一個synchronized方法只能由一個線程訪問。 37,try 里有一個return語句,那么緊跟在這個try后的

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論