激情欧美日韩一区二区,浪货撅高贱屁股求主人调教视频,精品无码成人片一区二区98,国产高清av在线播放,色翁荡息又大又硬又粗视频

北京瑞斯康達筆試題目附參考答案

時(shí)間:2022-12-12 07:39:39 筆試題目 我要投稿
  • 相關(guān)推薦

北京瑞斯康達筆試題目(附參考答案)

第一,談?wù)刦inal, finally, finalize的區別。
final?修飾符(關(guān)鍵字)如果一個(gè)類(lèi)被聲明為final,意味著(zhù)它不能再派生出新的子類(lèi),不能作為父類(lèi)被繼承。因此一個(gè)類(lèi)不能既被聲明為 abstract的,又被聲明為final的。將變量或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變量必須在聲明時(shí)給定初值,而在以后的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載。
finally?再異常處理時(shí)提供 finally 塊來(lái)執行任何清除操作。如果拋出一個(gè)異常,那么相匹配的 catch 子句就會(huì )執行,然后控制就會(huì )進(jìn)入 finally 塊(如果有的話(huà))。
finalize?方法名。Java 技術(shù)允許使用 finalize() 方法在垃圾收集器將對象從內存中清除出去之前做必要的清理工作。這個(gè)方法是由垃圾收集器在確定這個(gè)對象沒(méi)有被引用時(shí)對這個(gè)對象調用的。它是在 Object 類(lèi)中定義的,因此所有的類(lèi)都繼承了它。子類(lèi)覆蓋 finalize() 方法以整理系統資源或者執行其他清理工作。finalize() 方法是在垃圾收集器刪除對象之前對這個(gè)對象調用的。

北京瑞斯康達筆試題目(附參考答案)

第二,Anonymous Inner Class (匿名內部類(lèi)) 是否可以extends(繼承)其它類(lèi),是否可以implements(實(shí)現)interface(接口)?

匿名的內部類(lèi)是沒(méi)有名字的內部類(lèi)。不能extends(繼承) 其它類(lèi),但一個(gè)內部類(lèi)可以作為一個(gè)接口,由另一個(gè)內部類(lèi)實(shí)現。

第三,Static Nested Class 和 Inner Class的不同,說(shuō)得越多越好(面試題有的很籠統)。
Nested Class (一般是C++的說(shuō)法),Inner Class (一般是JAVA的說(shuō)法)。Java內部類(lèi)與C++嵌套類(lèi)最大的不同就在于是否有指向外部的引用上。
注: 靜態(tài)內部類(lèi)(Inner Class)意味著(zhù)1創(chuàng )建一個(gè)static內部類(lèi)的對象,不需要一個(gè)外部類(lèi)對象,2不能從一個(gè)static內部類(lèi)的一個(gè)對象訪(fǎng)問(wèn)一個(gè)外部類(lèi)對象

第四,&和&&的區別。
&是位運算符。&&是布爾邏輯運算符。

第五,HashMap和Hashtable的區別。
都屬于Map接口的類(lèi),實(shí)現了將惟一鍵映射到特定的值上。
HashMap 類(lèi)沒(méi)有分類(lèi)或者排序。它允許一個(gè) null 鍵和多個(gè) null 值。
Hashtable 類(lèi)似于 HashMap,但是不允許 null 鍵和 null 值。它也比 HashMap 慢,因為它是同步的。

第六,Collection 和 Collections的區別。

Collections是個(gè)java.util下的類(lèi),它包含有各種有關(guān)集合操作的靜態(tài)方法。
Collection是個(gè)java.util下的接口,它是各種集合結構的父接口。。

第七,什么時(shí)候用assert。

斷言是一個(gè)包含布爾表達式的語(yǔ)句,在執行這個(gè)語(yǔ)句時(shí)假定該表達式為 true。如果表達式計算為 false,那么系統會(huì )報告一個(gè) AssertionError。它用于調試目的:
assert(a > 0); // throws an AssertionError if a <= 0
斷言可以有兩種形式:
assert Expression1 ;
assert Expression1 : Expression2 ;
Expression1 應該總是產(chǎn)生一個(gè)布爾值。
Expression2 可以是得出一個(gè)值的任意表達式。這個(gè)值用于生成顯示更多調試信息的 String 消息。
斷言在默認情況下是禁用的。要在編譯時(shí)啟用斷言,需要使用 source 1.4 標記:
javac -source 1.4 Test.java
要在運行時(shí)啟用斷言,可使用 -enableassertions 或者 -ea 標記。
要在運行時(shí)選擇禁用斷言,可使用 -da 或者 -disableassertions 標記。
要系統類(lèi)中啟用斷言,可使用 -esa 或者 -dsa 標記。還可以在包的基礎上啟用或者禁用斷言。
可以在預計正常情況下不會(huì )到達的任何位置上放置斷言。斷言可以用于驗證傳遞給私有方法的參數。不過(guò),斷言不應該用于驗證傳遞給公有方法的參數,因為不管是否啟用了斷言,公有方法都必須檢查其參數。不過(guò),既可以在公有方法中,也可以在非公有方法中利用斷言測試后置條件。另外,斷言不應該以任何方式改變程序的狀態(tài)。

第八,GC是什么? 為什么要有GC? (基礎)。
GC是垃圾收集器。Java 程序員不用擔心內存管理,因為垃圾收集器會(huì )自動(dòng)進(jìn)行管理。要請求垃圾收集,可以調用下面的方法之一:
System.gc()
Runtime.getRuntime().gc()

第九,String s = new String("xyz");創(chuàng )建了幾個(gè)String Object?

兩個(gè)對象,一個(gè)是"xyx",一個(gè)是指向"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型?尚薷臑閟1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正確。

第十二,sleep() 和 wait() 有什么區別? 搞線(xiàn)程的最?lèi)?ài)


sleep()方法是使線(xiàn)程停止一段時(shí)間的方法。在sleep 時(shí)間間隔期滿(mǎn)后,線(xiàn)程不一定立即恢復執行。這是因為在那個(gè)時(shí)刻,其它線(xiàn)程可能正在運行而且沒(méi)有被調度為放棄執行,除非(a)"醒來(lái)"的線(xiàn)程具有更高的優(yōu)先級
(b)正在運行的線(xiàn)程因為其它原因而阻塞。
wait()是線(xiàn)程交互時(shí),如果線(xiàn)程對一個(gè)同步對象x 發(fā)出一個(gè)wait()調用,該線(xiàn)程會(huì )暫停執行,被調對象進(jìn)入等待狀態(tài),直到被喚醒或等待時(shí)間到。

第十三,Java有沒(méi)有g(shù)oto?
Goto?java中的保留字,現在沒(méi)有在java中使用。

第十四,數組有沒(méi)有length()這個(gè)方法? String有沒(méi)有length()這個(gè)方法?
數組沒(méi)有length()這個(gè)方法,有length的屬性。
String有length()這個(gè)方法。

第十五,Overload和Override的區別。Overloaded的方法是否可以改變返回值的類(lèi)型?
方法的重寫(xiě)Overriding和重載Overloading是Java多態(tài)性的不同表現。重寫(xiě)Overriding是父類(lèi)與子類(lèi)之間多態(tài)性的一種表現,重載Overloading是一個(gè)類(lèi)中多態(tài)性的一種表現。如果在子類(lèi)中定義某方法與其父類(lèi)有相同的名稱(chēng)和參數,我們說(shuō)該方法被重寫(xiě) (Overriding)。子類(lèi)的對象使用這個(gè)方法時(shí),將調用子類(lèi)中的定義,對它而言,父類(lèi)中的定義如同被"屏蔽"了。如果在一個(gè)類(lèi)中定義了多個(gè)同名的方法,它們或有不同的參數個(gè)數或有不同的參數類(lèi)型,則稱(chēng)為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類(lèi)型。

第十六,Set里的元素是不能重復的,那么用什么方法來(lái)區分重復與否呢? 是用==還是equals()? 它們有何區別?
Set里的元素是不能重復的,那么用iterator()方法來(lái)區分重復與否。equals()是判讀兩個(gè)Set是否相等。
equals()和==方法決定引用值是否指向同一對象equals()在類(lèi)中被覆蓋,為的是當兩個(gè)分離的對象的內容和類(lèi)型相配的話(huà),返回真值。

第十七,給我一個(gè)你最常見(jiàn)到的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

第十八,error和exception有什么區別?
error 表示恢復不是不可能但很困難的情況下的一種嚴重問(wèn)題。比如說(shuō)內存溢出。不可能指望程序能處理這樣的情況。
exception 表示一種設計或實(shí)現問(wèn)題。也就是說(shuō),它表示如果程序運行正常,從不會(huì )發(fā)生的情況。

第十九,List, Set, Map是否繼承自Collection接口?
List,Set是

Map不是

第二十,abstract class和interface有什么區別?
聲明方法的存在而不去實(shí)現它的類(lèi)被叫做抽象類(lèi)(abstract class),它用于要創(chuàng )建一個(gè)體現某些基本行為的類(lèi),并為該類(lèi)聲明方法,但不能在該類(lèi)中實(shí)現該類(lèi)的情況。不能創(chuàng )建abstract 類(lèi)的實(shí)例。然而可以創(chuàng )建一個(gè)變量,其類(lèi)型是一個(gè)抽象類(lèi),并讓它指向具體子類(lèi)的一個(gè)實(shí)例。不能有抽象構造函數或抽象靜態(tài)方法。Abstract 類(lèi)的子類(lèi)為它們父類(lèi)中的所有抽象方法提供實(shí)現,否則它們也是抽象類(lèi)為。取而代之,在子類(lèi)中實(shí)現該方法。知道其行為的其它類(lèi)可以在類(lèi)中實(shí)現這些方法。
接口(interface)是抽象類(lèi)的變體。在接口中,所有方法都是抽象的。多繼承性可通過(guò)實(shí)現這樣的接口而獲得。接口中的所有方法都是抽象的,沒(méi)有一個(gè)有程序體。接口只可以定義static final成員變量。接口的實(shí)現與子類(lèi)相似,除了該實(shí)現類(lèi)不能從接口定義中繼承行為。當類(lèi)實(shí)現特殊接口時(shí),它定義(即將程序體給予)所有這種接口的方法。然后,它可以在實(shí)現了該接口的類(lèi)的任何對象上調用接口的方法。由于有抽象類(lèi),它允許使用接口名作為引用變量的類(lèi)型。通常的動(dòng)態(tài)聯(lián)編將生效。引用可以轉換到接口類(lèi)型或從接口類(lèi)型轉換,instanceof 運算符可以用來(lái)決定某對象的類(lèi)是否實(shí)現了接口。

第二十一,abstract的method是否可同時(shí)是static,是否可同時(shí)是native,是否可同時(shí)是synchronized?
都不能

第二十二,接口是否可繼承接口? 抽象類(lèi)是否可實(shí)現(implements)接口? 抽象類(lèi)是否可繼承實(shí)體類(lèi)(concrete class)?
接口可以繼承接口。抽象類(lèi)可以實(shí)現(implements)接口,抽象類(lèi)是否可繼承實(shí)體類(lèi),但前提是實(shí)體類(lèi)必須有明確的構造函數。

第二十三,啟動(dòng)一個(gè)線(xiàn)程是用run()還是start()?
啟動(dòng)一個(gè)線(xiàn)程是調用start()方法,使線(xiàn)程所代表的虛擬處理機處于可運行狀態(tài),這意味著(zhù)它可以由JVM調度并執行。這并不意味著(zhù)線(xiàn)程就會(huì )立即運行。run()方法可以產(chǎn)生必須退出的標志來(lái)停止一個(gè)線(xiàn)程。

第二十四,構造器Constructor是否可被override?
構造器Constructor不能被繼承,因此不能重寫(xiě)Overriding,但可以被重載Overloading。

第二十五,是否可以繼承String類(lèi)?


String類(lèi)是final類(lèi)故不可以繼承。

第二十六,當一個(gè)線(xiàn)程進(jìn)入一個(gè)對象的一個(gè)synchronized方法后,其它線(xiàn)程是否可進(jìn)入此對象的其它方法?
不能,一個(gè)對象的一個(gè)synchronized方法只能由一個(gè)線(xiàn)程訪(fǎng)問(wèn)。

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

第二十八,編程題: 用最有效率的方法算出2乘以8等於幾?
有C背景的程序員特別喜歡問(wèn)這種問(wèn)題。

2 << 3

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

第三十,當一個(gè)對象被當作參數傳遞到一個(gè)方法后,此方法可改變這個(gè)對象的屬性,并可返回變化后的結果,那么這里到底是值傳遞還是引用傳遞?
是值傳遞。Java 編程語(yǔ)言只由值傳遞參數。當一個(gè)對象實(shí)例作為一個(gè)參數被傳遞到方法中時(shí),參數的值就是對該對象的引用。對象的內容可以在被調用的方法中改變,但對象的引用是永遠不會(huì )改變的。

第三十一,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
switch(expr1)中,expr1是一個(gè)整數表達式。因此傳遞給 switch 和 case 語(yǔ)句的參數應該是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。

第三十二,編程題: 寫(xiě)一個(gè)Singleton出來(lái)。
Singleton模式主要作用是保證在Java應用程序中,一個(gè)類(lèi)Class只有一個(gè)實(shí)例存在。
一般Singleton模式通常有幾種種形式:
第一種形式: 定義一個(gè)類(lèi),它的構造函數為private的,它有一個(gè)static的private的該類(lèi)變量,在類(lèi)初始化時(shí)實(shí)例話(huà),通過(guò)一個(gè)public的getInstance方法獲取對它的引用,繼而調用其中的方法。
public class Singleton {
private Singleton(){}
//在自己內部定義自己一個(gè)實(shí)例,是不是很奇怪?
//注意這是private 只供內部調用
private static Singleton instance = new Singleton();
//這里提供了一個(gè)供外部訪(fǎng)問(wèn)本class的靜態(tài)方法,可以直接訪(fǎng)問(wèn)
public static Singleton getInstance() {
return instance;
}
}
第二種形式:
public class Singleton {
private static Singleton instance = null;
public static synchronized Singleton getInstance() {
//這個(gè)方法比上面有所改進(jìn),不用每次都進(jìn)行生成對象,只是第一次
//使用時(shí)生成實(shí)例,提高了效率!
if (instance==null)
instance=new Singleton();
return instance;   }
}
其他形式:
定義一個(gè)類(lèi),它的構造函數為private的,所有方法為static的。
一般認為第一種形式要更加安全些

第三十三 Hashtable和HashMap
Hashtable繼承自Dictionary類(lèi),而HashMap是Java1.2引進(jìn)的Map interface的一個(gè)實(shí)現

HashMap允許將null作為一個(gè)entry的key或者value,而Hashtable不允許

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

最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在
多個(gè)線(xiàn)程訪(fǎng)問(wèn)Hashtable時(shí),不需要自己為它的方法實(shí)現同步,而HashMap
就必須為之提供外同步。

Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會(huì )有很大的差異。

1:abstract的method是否可同時(shí)是static,是否可同時(shí)是native,是否可同時(shí)是synchronized?

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

3:Set里的元素是不能重復的,那么用什么方法來(lái)區分重復與否呢? 是用==還是equals()? 它們
有何區別?

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

5:當一個(gè)線(xiàn)程進(jìn)入一個(gè)對象的一個(gè)synchronized方法后,其它線(xiàn)程是否可進(jìn)入此對象的其它方法?

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

 

關(guān)于參數傳遞:

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

現給一些參考:

第一,JAVA 里的參數傳遞只有值傳遞,沒(méi)有所謂的引用傳遞。(說(shuō)白了,是因為大家的說(shuō)法
不統一)
第二,引用一個(gè)強人的觀(guān)點(diǎn) jamesfancy()邊城狂人(James Fancy) :

"1. 首先明白參數的傳遞實(shí)質(zhì)是壓棧和出棧的過(guò)程。即在調用一個(gè)方法(或說(shuō)子程序)之前,先將需要傳入的參數壓棧,然后執行代碼的指針跳轉到方法的起始位置,進(jìn)行出棧操作,原來(lái)壓入棧中的參數取出置入方法中的局部變量(這里即參數變量)。

2. 對于基本類(lèi)型,傳遞的參數都是對原變量值的拷貝。每一個(gè)基本類(lèi)型的數據都是以字節形式保存在內存中的(如整型是4個(gè)字節,長(cháng)整型是8個(gè)字節等),壓棧時(shí)會(huì )將內存中的變量值按字節存入棧中,而原變量的值(即保存在原位置的內容)并不改變??內存中的數據是保存在堆中的,參數是保存在棧中的,總不可能把內存塊搬過(guò)來(lái)是吧......所以一定是拷貝的!

3. 先搞明白引用的實(shí)質(zhì)。當一個(gè)對象創(chuàng )建后,它的內容(N個(gè)字節)被保存在內存中。它的位置,即一個(gè)地址址,被返回,保存在一個(gè)引用變量中??所以實(shí)際上一個(gè)引用變量保存的只是某個(gè)類(lèi)的地址,而引用的類(lèi)型,并不會(huì )改變引用變量的大小,它只是說(shuō)明一個(gè)對象的數據大小。這樣,就可以從引用變量找到對象的起始地址,再通過(guò)類(lèi)型,獲取對象數據。而通過(guò)引用調用的方法,屬性這些東西,就是通過(guò)在這塊內存地址中的位置偏移來(lái)尋址的。(當然,實(shí)際的操作會(huì )比我說(shuō)的復雜得多,因為還涉及向上向下傳型等問(wèn)題)

4. 引用參數的傳遞,實(shí)際上就是傳遞的引用變量的值,這和傳遞基本類(lèi)型的值原理是一樣的。但由于引用變量其值的特殊性(只是一個(gè)地址,這個(gè)地址上保存的才是對象的實(shí)際數據),所以,引用變量的值傳入參數變量后,通過(guò)參數變量對對象的修改(在實(shí)際地址上的操作)自然就會(huì )影響到同一個(gè)對象。??這里,外面的引用變量和參數變量,本身是不同的,但是它們的值相同,都是對象的地址。"
不是打基礎,打基礎吧!

【北京瑞斯康達筆試題目附參考答案】相關(guān)文章:

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

富士康筆試題目及答案08-11

2016富士康筆試英語(yǔ)題目07-28

富士康(太原)筆試題題目08-10

成都邁瑞營(yíng)銷(xiāo)專(zhuān)員的筆試題目08-10

富士康筆試題目及答案201508-12

2015富士康筆試題目及答案08-15

富士康筆試題目答案201508-13

光大銀行北京分行的筆試題目08-09

飛亞達的筆試題目和一面體驗08-10

激情欧美日韩一区二区,浪货撅高贱屁股求主人调教视频,精品无码成人片一区二区98,国产高清av在线播放,色翁荡息又大又硬又粗视频