中文字幕在线一区二区在线,久久久精品免费观看国产,无码日日模日日碰夜夜爽,天堂av在线最新版在线,日韩美精品无码一本二本三本,麻豆精品三级国产国语,精品无码AⅤ片,国产区在线观看视频

      瑞斯康達筆試題目及參考答案

      時間:2024-10-13 12:23:09 面試筆試 我要投稿
      • 相關推薦

      瑞斯康達筆試題目及參考答案

      第一,談談final, finally, finalize的區(qū)別。

        final?修飾符(關鍵字)如果一個類被聲明為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為 abstract的,又被聲明為final的。將變量或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變量必須在聲明時給定初值,而在以后的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載。

        finally?再異常處理時提供 finally 塊來執(zhí)行任何清除操作。如果拋出一個異常,那么相匹配的 catch 子句就會執(zhí)行,然后控制就會進入 finally 塊(如果有的話)。

        finalize?方法名。java 技術允許使用 finalize() 方法在垃圾收集器將對象從內存中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在確定這個對象沒有被引用時對這個對象調用的。它是在 object 類中定義的,因此所有的類都繼承了它。子類覆蓋 finalize() 方法以整理系統(tǒng)資源或者執(zhí)行其他清理工作。finalize() 方法是在垃圾收集器刪除對象之前對這個對象調用的。

        第二,anonymous inner class (匿名內部類) 是否可以extends(繼承)其它類,是否可以implements(實現(xiàn))interface(接口)?

        匿名的內部類是沒有名字的內部類。不能extends(繼承) 其它類,但一個內部類可以作為一個接口,由另一個內部類實現(xiàn)。

        第三,static nested class 和 inner class的不同,說得越多越好(面試題有的很籠統(tǒng))。

        nested class (一般是c++的說法),inner class (一般是java的說法)。java內部類與c++嵌套類最大的不同就在于是否有指向外部的引用上。

        注: 靜態(tài)內部類(inner class)意味著1創(chuàng)建一個static內部類的對象,不需要一個外部類對象,2不能從一個static內部類的一個對象訪問一個外部類對象

        第四,&和&&的區(qū)別。

        &是位運算符。&&是布爾邏輯運算符。

        第五,hashmap和hashtable的區(qū)別。

        都屬于map接口的類,實現(xiàn)了將惟一鍵映射到特定的值上。

        hashmap 類沒有分類或者排序。它允許一個 null 鍵和多個 null 值。

        hashtable 類似于 hashmap,但是不允許 null 鍵和 null 值。它也比 hashmap 慢,因為它是同步的。

        第六,collection 和 collections的區(qū)別。

        collections是個java.util下的類,它包含有各種有關集合操作的靜態(tài)方法。

        collection是個java.util下的接口,它是各種集合結構的父接口。。

        第七,什么時候用assert。

        斷言是一個包含布爾表達式的語句,在執(zhí)行這個語句時假定該表達式為 true。如果表達式計算為 false,那么系統(tǒng)會報告一個 assertionerror。它用于調試目的:

        assert(a > 0); // throws an assertionerror if a <= 0

        斷言可以有兩種形式:

        assert expression1 ;

        assert expression1 : expression2 ;

        expression1 應該總是產生一個布爾值。

        expression2 可以是得出一個值的任意表達式。這個值用于生成顯示更多調試信息的 string 消息。

        斷言在默認情況下是禁用的。要在編譯時啟用斷言,需要使用 source 1.4 標記:

        javac -source 1.4 test.java

        要在運行時啟用斷言,可使用 -enableassertions 或者 -ea 標記。

        要在運行時選擇禁用斷言,可使用 -da 或者 -disableassertions 標記。

        要系統(tǒng)類中啟用斷言,可使用 -esa 或者 -dsa 標記。還可以在包的基礎上啟用或者禁用斷言。

        可以在預計正常情況下不會到達的任何位置上放置斷言。斷言可以用于驗證傳遞給私有方法的參數(shù)。不過,斷言不應該用于驗證傳遞給公有方法的參數(shù),因為不管是否啟用了斷言,公有方法都必須檢查其參數(shù)。不過,既可以在公有方法中,也可以在非公有方法中利用斷言測試后置條件。另外,斷言不應該以任何方式改變程序的狀態(tài)。

        第八,gc是什么? 為什么要有gc? (基礎)。

        gc是垃圾收集器。java 程序員不用擔心內存管理,因為垃圾收集器會自動進行管理。要請求垃圾收集,可以調用下面的方法之一:

        system.gc()

        runtime.getruntime().gc()

        第九,string s = new string("xyz");創(chuàng)建了幾個string object?

        兩個對象,一個是"xyx",一個是指向"xyx"的引用對象s。

        第十,math.round(11.5)等於多少? math.round(-11.5)等於多少?

        math.round(11.5)返回(long)12,math.round(-11.5)返回(long)-11;

        第十一,short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯?

        short s1 = 1; s1 = s1 + 1;有錯,s1是short型,s1+1是int型,不能顯式轉化為short型。可修改為s1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正確。

        第十二,sleep() 和 wait() 有什么區(qū)別? 搞線程的最愛

        sleep()方法是使線程停止一段時間的方法。在sleep 時間間隔期滿后,線程不一定立即恢復執(zhí)行。這是因為在那個時刻,其它線程可能正在運行而且沒有被調度為放棄執(zhí)行,除非(a)"醒來"的線程具有更高的優(yōu)先級

        (b)正在運行的線程因為其它原因而阻塞。

        wait()是線程交互時,如果線程對一個同步對象x 發(fā)出一個wait()調用,該線程會暫停執(zhí)行,被調對象進入等待狀態(tài),直到被喚醒或等待時間到。

        第十三,java有沒有goto?

        goto?java中的保留字,現(xiàn)在沒有在java中使用。

        第十四,數(shù)組有沒有l(wèi)ength()這個方法? string有沒有l(wèi)ength()這個方法?

        數(shù)組沒有l(wèi)ength()這個方法,有l(wèi)ength的屬性。

        string有l(wèi)ength()這個方法。

        第十五,overload和override的區(qū)別。overloaded的方法是否可以改變返回值的類型?

        方法的重寫overriding和重載overloading是java多態(tài)性的不同表現(xiàn)。重寫overriding是父類與子類之間多態(tài)性的一種表現(xiàn),重載overloading是一個類中多態(tài)性的一種表現(xiàn)。如果在子類中定義某方法與其父類有相同的名稱和參數(shù),我們說該方法被重寫 (overriding)。子類的對象使用這個方法時,將調用子類中的定義,對它而言,父類中的定義如同被"屏蔽"了。如果在一個類中定義了多個同名的方法,它們或有不同的參數(shù)個數(shù)或有不同的參數(shù)類型,則稱為方法的重載(overloading)。overloaded的方法是可以改變返回值的類型。

        第十六,set里的元素是不能重復的,那么用什么方法來區(qū)分重復與否呢? 是用還是equals()? 它們有何區(qū)別?

        set里的元素是不能重復的,那么用iterator()方法來區(qū)分重復與否。equals()是判讀兩個set是否相等。

        equals()和方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當兩個分離的對象的內容和類型相配的話,返回真值。

        第十七,給我一個你最常見到的runtime exception。

        arithmeticexception,arraystoreexception, bufferoverflowexception, bufferunderflowexception,cannotredoexception,cannotundoexception, classcastexception,cmmexception,concurrentmodificationexception, domexception,emptystackexception,illegalargumentexception, illegalmonitorstateexception,illegalpathstateexception, illegalstateexception, imagingopexception, indexoutofbounds e xception, missingresourceexception, negativearraysizeexception, nosuchelementexception, nullpointerexception, profiledataexception, providerexception, rasterformatexception, securityexception, systemexception, undeclaredthrowableexception, unmodifiablesetexception, unsupportedoperationexception

        第十八,error和exception有什么區(qū)別?

        error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指望程序能處理這樣的情況。

        exception 表示一種設計或實現(xiàn)問題。也就是說,它表示如果程序運行正常,從不會發(fā)生的情況。

        第十九,list, set, map是否繼承自collection接口?

        list,set是

        map不是

        第二十,abstract class和interface有什么區(qū)別?

        聲明方法的存在而不去實現(xiàn)它的類被叫做抽象類(abstract class),它用于要創(chuàng)建一個體現(xiàn)某些基本行為的類,并為該類聲明方法,但不能在該類中實現(xiàn)該類的情況。不能創(chuàng)建abstract 類的實例。然而可以創(chuàng)建一個變量,其類型是一個抽象類,并讓它指向具體子類的一個實例。不能有抽象構造函數(shù)或抽象靜態(tài)方法。abstract 類的子類為它們父類中的所有抽象方法提供實現(xiàn),否則它們也是抽象類為。取而代之,在子類中實現(xiàn)該方法。知道其行為的其它類可以在類中實現(xiàn)這些方法。

        接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過實現(xiàn)這樣的接口而獲得。接口中的所有方法都是抽象的,沒有一個有程序體。接口只可以定義static final成員變量。接口的實現(xiàn)與子類相似,除了該實現(xiàn)類不能從接口定義中繼承行為。當類實現(xiàn)特殊接口時,它定義(即將程序體給予)所有這種接口的方法。然后,它可以在實現(xiàn)了該接口的類的任何對象上調用接口的方法。由于有抽象類,它允許使用接口名作為引用變量的類型。通常的動態(tài)聯(lián)編將生效。引用可以轉換到接口類型或從接口類型轉換,instanceof 運算符可以用來決定某對象的類是否實現(xiàn)了接口。

        第二十一,abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized?

        都不能

        第二十二,接口是否可繼承接口? 抽象類是否可實現(xiàn)(implements)接口? 抽象類是否可繼承實體類(concrete class)?

        接口可以繼承接口。抽象類可以實現(xiàn)(implements)接口,抽象類是否可繼承實體類,但前提是實體類必須有明確的構造函數(shù)。

        第二十三,啟動一個線程是用run()還是start()?

        啟動一個線程是調用start()方法,使線程所代表的虛擬處理機處于可運行狀態(tài),這意味著它可以由jvm調度并執(zhí)行。這并不意味著線程就會立即運行。run()方法可以產生必須退出的標志來停止一個線程。

        第二十四,構造器constructor是否可被override?

        構造器constructor不能被繼承,因此不能重寫overriding,但可以被重載overloading。

        第二十五,是否可以繼承string類?

        string類是final類故不可以繼承。

        第二十六,當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法?

        不能,一個對象的一個synchronized方法只能由一個線程訪問。

        第二十七,try {}里有一個return語句,那么緊跟在這個try后的finally {}里的code會不會被執(zhí)行,什么時候被執(zhí)行,在return前還是后?

        會執(zhí)行,在return前執(zhí)行。

        第二十八,編程題: 用最有效率的方法算出2乘以8等於幾?

        有c背景的程序員特別喜歡問這種問題。

        2 << 3

        第二十九,兩個對象值相同(x.equals(y) true),但卻可有不同的hash code,這句話對不對?

        不對,有相同的hash code。

        第三十,當一個對象被當作參數(shù)傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞?

        是值傳遞。java 編程語言只由值傳遞參數(shù)。當一個對象實例作為一個參數(shù)被傳遞到方法中時,參數(shù)的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會改變的。

        第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在string上?

        switch(expr1)中,expr1是一個整數(shù)表達式。因此傳遞給 switch 和 case 語句的參數(shù)應該是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。

        第三十二,編程題: 寫一個singleton出來。

        singleton模式主要作用是保證在java應用程序中,一個類class只有一個實例存在。

        一般singleton模式通常有幾種種形式:

        第一種形式: 定義一個類,它的構造函數(shù)為private的,它有一個static的private的該類變量,在類初始化時實例話,通過一個public的getinstance方法獲取對它的引用,繼而調用其中的方法。

        public class singleton {

        private singleton(){}

        //在自己內部定義自己一個實例,是不是很奇怪?

        //注意這是private 只供內部調用

        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 (instancenull)

        instance=new singleton();

        return instance;   }

        }

        其他形式:

        定義一個類,它的構造函數(shù)為private的,所有方法為static的。

        一般認為第一種形式要更加安全些

        第三十三 hashtable和hashmap

        hashtable繼承自dictionary類,而hashmap是java1.2引進的map interface的一個實現(xiàn)

        hashmap允許將null作為一個entry的key或者value,而hashtable不允許

        還有就是,hashmap把hashtable的contains方法去掉了,改成containsvalue和containskey。因為contains方法容易讓人引起誤解。

        最大的不同是,hashtable的方法是synchronize的,而hashmap不是,在

        多個線程訪問hashtable時,不需要自己為它的方法實現(xiàn)同步,而hashmap

        就必須為之提供外同步。

        hashtable和hashmap采用的hash/rehash算法都大概一樣,所以性能不會有很大的差異。

        1:abstract的method是否可同時是static,是否可同時是native,是否可同時是synchronized?

        2:當一個對象被當作參數(shù)傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的

        結果,那么這里到底是值傳遞還是引用傳遞?

        3:set里的元素是不能重復的,那么用什么方法來區(qū)分重復與否呢? 是用還是equals()? 它們

        有何區(qū)別?

        4:構造器constructor是否可被override?

        5:當一個線程進入一個對象的一個synchronized方法后,其它線程是否可進入此對象的其它方法?

        6:兩個對象值相同(x.equals(y) true),但卻可有不同的hash code,這句話對不對

        關于參數(shù)傳遞:

        其實java里對參數(shù)的傳遞在國際上都是一直有爭論的。包括《think in java》里都提到了,bruce eckel 也沒給出定論。我覺得這很大程度上是由于規(guī)范不嚴格造成的。因為大家都知道參數(shù)傳遞的本質是什么,但描述方式不一樣,以致造成答案不一致。

        現(xiàn)給一些參考:

        第一,java 里的參數(shù)傳遞只有值傳遞,沒有所謂的引用傳遞。(說白了,是因為大家的說法

        不統(tǒng)一)

        第二,引用一個強人的觀點 jamesfancy()邊城狂人(james fancy) :

      【瑞斯康達筆試題目及參考答案】相關文章:

      富士康筆試題目及答案03-30

      富士康廊坊的筆試題目11-21

      達能的筆試題目和經驗分享11-21

      邁瑞筆試題目硬件研發(fā)工程師11-21

      中瑞岳華筆試11-21

      邁瑞筆試經驗分享11-21

      路易達孚筆試11-21

      華夏的筆試題目11-21

      南航筆試題目06-23

      有關富士康招聘筆試11-21

      主站蜘蛛池模板: 亚洲av午夜成人片精品 | 亚洲AV无码一区二区一二区色戒 | 精品一区二区三区人妻久久| 将乐县| 亚洲成av人无码免费观看| 国产成人一区二区三区视频在线| 国产成人av在线影院无毒| 99久久精品国产毛片| 浦城县| 兴义市| 国产精品无码久久AⅤ人妖| 日韩中文字幕三级有码区| 国产一区二区三区免费精品| 中文字幕av日韩精品一区| 国产区二区三区在线观看| 长泰县| 秦皇岛市| 久久精品天堂一区二区三区| 沂源县| 文化| 日本一区二区三区看片| 卓资县| 中文字幕少妇人妻视频| 久久99精品久久久久九色| 视频精品熟女一区二区三区| 美女被射视频在线观看91| 强d漂亮少妇高潮在线观看| 亚洲无码性爱视频在线观看| 亚洲一区二区三区久久综合| 博客| 亚洲精品国产福利在线观看| 青青草视频在线观看播放| 爆乳无码AV国内| 亚洲国产成a人v在线观看| 国产精品久久久久亚洲| 极品av在线播放| 日本精品视频一区二区国产| 青青草视频华人绿色在线| 免费人成视频网站在线| 大伊香蕉精品视频一区| 91色婷婷成人精品亚洲|