常見(jiàn)java應聘筆試題

時(shí)間:2022-06-25 07:14:13 筆試 我要投稿
  • 相關(guān)推薦

常見(jiàn)java應聘筆試題

  在java工作求職中,筆試是檢驗求職者的一個(gè)重要方式,通過(guò)筆試,能看出求職者的水平,那么有哪些java常見(jiàn)的筆試題呢?下面小編就帶大家一起來(lái)看看這些為大家收集整理的常見(jiàn)java應聘筆試題吧!

常見(jiàn)java應聘筆試題

  常見(jiàn)java應聘筆試題

  1. Java中sleep和wait的區別

 、 這兩個(gè)方法來(lái)自不同的類(lèi)分別是,sleep來(lái)自Thread類(lèi),和wait來(lái)自Object類(lèi)。

  sleep是Thread的靜態(tài)類(lèi)方法,誰(shuí)調用的誰(shuí)去睡覺(jué),即使在a線(xiàn)程里調用b的sleep方法,實(shí)際上還是a去睡覺(jué),要讓b線(xiàn)程睡覺(jué)要在b的代碼中調用sleep。

 、 鎖: 最主要是sleep方法沒(méi)有釋放鎖,而wait方法釋放了鎖,使得其他線(xiàn)程可以使用同步控制塊或者方法。

  sleep不出讓系統資源;wait是進(jìn)入線(xiàn)程等待池等待,出讓系統資源,其他線(xiàn)程可以占用CPU。一般wait不會(huì )加時(shí)間限制,因為如果wait線(xiàn)程的運行資源不夠,再出來(lái)也沒(méi)用,要等待其他線(xiàn)程調用notify/notifyAll喚醒等待池中的所有線(xiàn)程,才會(huì )進(jìn)入就緒隊列等待OS分配系統資源。sleep(milliseconds)可以用時(shí)間指定使它自動(dòng)喚醒過(guò)來(lái),如果時(shí)間不到只能調用interrupt()強行打斷。

  Thread.sleep(0)的作用是“觸發(fā)操作系統立刻重新進(jìn)行一次CPU競爭”。

 、 使用范圍:wait,notify和notifyAll只能在同步控制方法或者同步控制塊里面使用,而sleep可以在任何地方使用。

  synchronized(x){   x.notify()   //或者wait()  }

  2. Java中HashMap和HashTable的區別

 、 歷史原因: Hashtable是給予陳舊的Dictonary類(lèi)的, HashMap是Java1.2引進(jìn)的Map接口的一個(gè)實(shí)現

 、 HashMap允許空的鍵值對, 而HashTable不允許

 、 HashTable同步,而HashMap非同步,效率上比HashTable要高

  3. 請簡(jiǎn)述在異常當中,throw和throws有什么區別

 、 throw代表動(dòng)作,表示拋出一個(gè)異常的動(dòng)作;throws代表一種狀態(tài),代表方法可能有異常拋出

 、 throw用在方法實(shí)現中,而throws用在方法聲明中

 、 throw只能用于拋出一種異常,而throws可以?huà)伋龆鄠(gè)異常

  4. 內存溢出和內存泄露的區別

  內存溢出 out of memory,是指程序在申請內存時(shí),沒(méi)有足夠的內存空間供其使用,出現out of memory;比如申請了一個(gè)integer,但給它存了long才能存下的數,那就是內存溢出。

  內存泄露 memory leak,是指程序在申請內存后,無(wú)法釋放已申請的內存空間,一次內存泄露危害可以忽略,但內存泄露堆積后果很?chē)乐,無(wú)論多少內存,遲早會(huì )被占光。

  memory leak會(huì )最終會(huì )導致out of memory!

  內存溢出就是你要求分配的內存超出了系統能給你的,系統不能滿(mǎn)足需求,于是產(chǎn)生溢出。

  內存泄漏是指你向系統申請分配內存進(jìn)行使用(new),可是使用完了以后卻不歸還(),結果你申請到的那塊內存你自己也不能再訪(fǎng)問(wèn)(也許你把它的地址給弄丟了),而系統也不能再次將它分配給需要的程序。一個(gè)盤(pán)子用盡各種方法只能裝4個(gè)果子,你裝了5個(gè),結果掉倒地上不能吃了。這就是溢出!比方說(shuō)棧,棧滿(mǎn)時(shí)再做進(jìn)棧必定產(chǎn)生空間溢出,叫上溢,?諘r(shí)再做退棧也產(chǎn)生空間溢出,稱(chēng)為下溢。就是分配的內存不足以放下數據項序列,稱(chēng)為內存溢出。

  以發(fā)生的方式來(lái)分類(lèi),內存泄漏可以分為4類(lèi):

 、 常發(fā)性?xún)却嫘孤。發(fā)生內存泄漏的代碼會(huì )被多次執行到,每次被執行的時(shí)候都會(huì )導致一塊內存泄漏。

 、 偶發(fā)性?xún)却嫘孤。發(fā)生內存泄漏的代碼只有在某些特定環(huán)境或操作過(guò)程下才會(huì )發(fā)生。常發(fā)性和偶發(fā)性是相對的。對于特定的環(huán)境,偶發(fā)性的也許就變成了常發(fā)性的。所以測試環(huán)境和測試方法對檢測內存泄漏至關(guān)重要。

 、 一次性?xún)却嫘孤。發(fā)生內存泄漏的代碼只會(huì )被執行一次,或者由于算法上的缺陷,導致總會(huì )有一塊僅且一塊內存發(fā)生泄漏。比如,在類(lèi)的構造函數中分配內存,在析構函數中卻沒(méi)有釋放該內存,所以?xún)却嫘孤┲粫?huì )發(fā)生一次。

 、 隱式內存泄漏。程序在運行過(guò)程中不停的分配內存,但是直到結束的時(shí)候才釋放內存。嚴格的說(shuō)這里并沒(méi)有發(fā)生內存泄漏,因為最終程序釋放了所有申請的內存。但是對于一個(gè)服務(wù)器程序,需要運行幾天,幾周甚至幾個(gè)月,不及時(shí)釋放內存也可能導致最終耗盡系統的所有內存。所以,我們稱(chēng)這類(lèi)內存泄漏為隱式內存泄漏。

  從用戶(hù)使用程序的角度來(lái)看,內存泄漏本身不會(huì )產(chǎn)生什么危害,作為一般的用戶(hù),根本感覺(jué)不到內存泄漏的存在。真正有危害的.是內存泄漏的堆積,這會(huì )最終消耗盡系統所有的內存。從這個(gè)角度來(lái)說(shuō),一次性?xún)却嫘孤┎](méi)有什么危害,因為它不會(huì )堆積,而隱式內存泄漏危害性則非常大,因為較之于常發(fā)性和偶發(fā)性?xún)却嫘孤┧y被檢測到。

  5. String,StringBuffer 和 StringBuilder的區別

 、倏勺兣c不可變

  String類(lèi)中使用字符數組保存字符串,如下就是,因為有“final”修飾符,所以可以知道string對象是不可變的。

  private final char value[];

  StringBuilder與StringBuffer都繼承自AbstractStringBuilder類(lèi),在A(yíng)bstractStringBuilder中也是使用字符數組保存字符串,如下就是,可知這兩種對象都是可變的。

  char[] value;

 、谑欠穸嗑(xiàn)程安全

  String中的對象是不可變的,也就可以理解為常量,顯然線(xiàn)程安全。

  AbstractStringBuilder是StringBuilder與StringBuffer的公共父類(lèi),定義了一些字符串的基本操作,如expandCapacity、append、、indexOf等公共方法。

  StringBuffer對方法加了同步鎖或者對調用的方法加了同步鎖,所以是線(xiàn)程安全的?慈缦略创a:

  public synchronized StringBuffer reverse() {   super.reverse();   return this;  }   public int indexOf(String str) {   return indexOf(str, 0);  //存在 public synchronized int indexOf(String str, int fromIndex) 方法  }

  StringBuilder并沒(méi)有對方法進(jìn)行加同步鎖,所以是非線(xiàn)程安全的。

 、跾tringBuilder與StringBuffer共同點(diǎn)

  StringBuilder與StringBuffer有公共父類(lèi)AbstractStringBuilder(抽象類(lèi))。

  抽象類(lèi)與接口的其中一個(gè)區別是:抽象類(lèi)中可以定義一些子類(lèi)的公共方法,子類(lèi)只需要增加新的功能,不需要重復寫(xiě)已經(jīng)存在的方法;而接口中只是對方法的申明和常量的定義。

  StringBuilder、StringBuffer的方法都會(huì )調用AbstractStringBuilder中的公共方法,如super.append(...)。只是StringBuffer會(huì )在方法上加synchronized關(guān)鍵字,進(jìn)行同步。

  最后,如果程序不是多線(xiàn)程的,那么使用StringBuilder效率高于StringBuffer。

  6. 數組和鏈表的區別

  二者都屬于一種數據結構

  從邏輯結構來(lái)看:

 、 數組必須事先定義固定的長(cháng)度(元素個(gè)數),不能適應數據動(dòng)態(tài)地增減的情況。當數據增加時(shí),可能超出原先定義的元素個(gè)數;當數據減少時(shí),造成內存浪費;數組可以根據下標直接存取。

 、 鏈表動(dòng)態(tài)地進(jìn)行存儲分配,可以適應數據動(dòng)態(tài)地增減的情況,且可以方便地插入、刪除數據項。(數組中插入、刪除數據項時(shí),需要移動(dòng)其它數據項,非常繁瑣)鏈表必須根據next指針找到下一個(gè)元素。

  從內存存儲來(lái)看:

 、(靜態(tài))數組從棧中分配空間,對于程序員方便快速,但是自由度小。

 、阪湵韽亩阎蟹峙淇臻g,自由度大但是申請管理比較麻煩。

  從上面的比較可以看出,如果需要快速訪(fǎng)問(wèn)數據,很少或不插入和刪除元素,就應該用數組;相反,如果需要經(jīng)常插入和刪除元素就需要用鏈表數據結構了。

  7. ArrayList和LinkedList的區別

 、貯rrayList是實(shí)現了基于動(dòng)態(tài)數組的數據結構,LinkedList基于鏈表的數據結構。

 、趯τ陔S機訪(fǎng)問(wèn)get和set,ArrayList覺(jué)得優(yōu)于LinkedList,因為L(cháng)inkedList要移動(dòng)指針。

 、蹖τ谛略龊蛣h除操作add和remove,LinedList比較占優(yōu)勢,因為ArrayList要移動(dòng)數據。

【常見(jiàn)java應聘筆試題】相關(guān)文章:

常見(jiàn)JAVA面試題(一)07-13

Java常見(jiàn)面試題(含答案)07-13

java常見(jiàn)的面試題和面試技巧 誰(shuí)能告訴我07-13

華為的JAVA筆試題07-11

華為Java筆試題07-11

Java筆試題推薦07-02

Java面試題07-12

JAVA題庫:JAVA面試題目整理07-11

華為Java面試題07-11

華為的JAVA面試題07-11

99久久精品免费看国产一区二区三区|baoyu135国产精品t|40分钟97精品国产最大网站|久久综合丝袜日本网|欧美videosdesexo肥婆