JDK閱讀筆記

OBJECT

clone();

一、Java中有兩種方式創(chuàng)建對象:1、使用new操作符創(chuàng)建對象;2、使用clone方法復制對象,并且clone要比創(chuàng)建一個新的對象的效率要高。

二、clone分為淺拷貝和深拷貝。淺拷貝指僅僅拷貝對象本身,如果對象中包含引用的對象,則不會被拷貝,深拷貝則會將引用對象一起拷貝。

三、要實現clone需要實現cloneable接口。如果沒有實現接口,直接clone則會拋出CloneNotSupportedException異常。

hashcode();

如何判別在集合中是否已經存在該對象了?一般我們會用到equals()方法,,如果采用equals方法去逐一比較,效率必然是一個問題。此時,我們就需要用到hasncode()方法。實際上在HashMap的具體實現中會用一個table保存已經存進去的對象的hashcode值,如果table中沒有該hashcode值,它就可以直接存進去,不用再進行任何比較了;如果存在該hashcode值, 就調用它的equals方法與新元素進行比較,相同的話就不存了,不相同就散列其它的地址,所以這里存在一個沖突解決的問題,這樣一來實際調用equals方法的次數就大大降低了,說通俗一點:Java中的hashCode方法就是根據一定的規(guī)則將與對象相關的信息(比如對象的存儲地址,對象的字段等)映射成一個數值,這個數值稱作為散列值。

不同的對象可能會產生相同的hashcode值,如果兩個對象的hashcode值不等,則必定是兩個不同的對象,所以,一般來說可以用hashcode()判斷兩個對象不相等,如果要判斷兩個對象相等需要使用到equal()方法。

notify()

notify方法只喚醒一個等待(對象的)線程并使該線程開始執(zhí)行。所以如果有多個線程等待一個對象,這個方法只會喚醒其中一個線程,選擇哪個線程取決于操作系統對多線程管理的實現。notifyAll 會喚醒所有等待(對象的)線程,盡管哪一個線程將會第一個處理取決于操作系統的實現。如果當前情況下有多個線程需要被喚醒,推薦使用notifyAll 方法。比如在生產者-消費者里面的使用,每次都需要喚醒所有的消費者或是生產者,以判斷程序是否可以繼續(xù)往下執(zhí)行

String

string.intern();

? ? ? jdk7 版本對 intern 操作和常量池都做了一定的修改。主要包括2點:

1、將String常量池從Perm區(qū)移動到了Java Heap區(qū)

2、String#intern方法時,如果存在堆中的對象,會直接保存對象的引用,而不會重新創(chuàng)建對象。

  在 Jdk6 以及以前的版本中,字符串的常量池是放在堆的Perm區(qū)的,Perm區(qū)是一個類靜態(tài)的區(qū)域,主要存儲一些加載類的信息,常量池,方法片段等內容,默認大小只有4m,一旦常量池中大量使用 intern 是會直接產生java.lang.OutOfMemoryError:PermGen space錯誤的

以下的程序作為理解:

String s =new String("1");

s.intern();

String s2 ="1";

System.out.println(s == s2);

String s3 =new String("1") +new String("1");

s3.intern();

String s4 ="11";

System.out.println(s3 == s4);

在jdk1.6以前結果為 false,false

在 jdk7 的版本中,false,true

AbstractStringBuilder

最大容量為Integer.MAX_VALUE-8

StringBuffer和StringBuilder

兩個默認的初始容量均為為16,前者是線程安全的因為它的方法均添加了鎖,

Thread

最小的權重是1,默認的權重是5,最大的權重為10

在thread類中,sleep,yield,join方法

(1)最簡單的區(qū)別是,wait方法依賴于同步,而sleep方法可以直接調用。而更深層次的區(qū)別在于sleep方法只是暫時讓出CPU的執(zhí)行權,并不釋放鎖。而wait方法則需要釋放鎖。

(2)yield方法的作用是暫停當前線程,以便其他線程有機會執(zhí)行,不過不能指定暫停的時間,并且也不能保證當前線程馬上停止。yield方法只是將Running狀態(tài)轉變?yōu)镽unnable狀態(tài)。

(3)join方法的作用是父線程等待子線程執(zhí)行完成后再執(zhí)行,換句話說就是將異步執(zhí)行的線程合并為同步的線程

線程

wait方法是一個本地方法,其底層是通過一個叫做監(jiān)視器鎖的對象來完成的。

如何獲取monitor對象所有權?Java中只能通過Synchronized關鍵字來完成

1)調用wait方法后,線程是會釋放對monitor對象的所有權的。

2)一個通過wait方法阻塞的線程,必須同時滿足以下兩個條件才能被真正執(zhí)行:

    線程需要被喚醒(超時喚醒或調用notify/notifyll)。

    線程喚醒后需要競爭到鎖(monitor)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • 引子 Map是各類開發(fā)中使用頻率很高的數據結構,它提供了一種我們在描述事物關系時非常重要的工具----映射。從接口...
    PhilicX閱讀 335評論 0 0
  • 1大同小異的工作周報 Sunny軟件公司一直使用自行開發(fā)的一套OA (Office Automatic,辦公自動化...
    justCode_閱讀 1,232評論 0 3
  • 引子 TimSort是一種穩(wěn)定的、自適應的變種歸并排序。當被應用在部分有序的數組排序問題時,TimSort有遠好于...
    PhilicX閱讀 888評論 0 2
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴謹 對...
    cosWriter閱讀 11,619評論 1 32
  • 百日練D17 《唯愛和美食不可辜負》P105-224,用時40分鐘。 其實是一本特別的食譜書,散文形式的食譜書。很...
    hello旁元蟹閱讀 185評論 0 0

友情鏈接更多精彩內容