《Effective Java》學(xué)習(xí)筆記
1、終結(jié)函數(shù)守衛(wèi)者
? * 通過終結(jié)函數(shù)守衛(wèi)者,我們能夠保證在外部類對象被回收之前的外部類對象的終結(jié)函數(shù)的調(diào)用
? * 應(yīng)外匿名類的對象的生命周期和Foo相同,而且在回收時先被回收,就守衛(wèi)了終結(jié)函數(shù)的調(diào)用
? * 能夠防止忘記或者惡意的不調(diào)用終結(jié)函數(shù)
2、final 變量只能在聲明時初始化或者在構(gòu)造方法中初始化
3、Junit中每次的運行測試案例,將會運行該案例中所有的測試方法。
4、因為HashMap使用Hash桶來放置對象,理想的情況每個Hash桶只有一個對象,但是一般而言很難,甚至可以形成具有相同的HashCode的鏈表
5、volatile 保證任何一個線程在讀取一個域的時候都將會看到最近剛剛被寫入的值。
?? 簡單的說volatile提供synchronized的可見性,而不提供互斥性。
?* 我想volatile,是這用關(guān)鍵字volatile修飾過的變量,放在主內(nèi)存中而不是線程的工作內(nèi)存
?* 這樣每次當(dāng)該變量的值改變的時候,就會在主內(nèi)存中改變。
?* 而一般的變量,將會在線程的工作內(nèi)存中保持一份拷貝,然后只在適當(dāng)?shù)臅r機,才會將變化寫入到主內(nèi)存
?* 對于同步塊而言,這個時機就是同步塊開始或結(jié)束,而其它的時機,我想是在當(dāng)前使用該變量語句后。
?* 當(dāng)然volatile變量不保證原子性(也就是volatile變量的使用,可能被其它的線程干擾,比如兩個線程同時對該變量操作,但是要在高壓的情況下才能出現(xiàn),要實現(xiàn)原子性必須對該變量加鎖。),僅保證可見性(總是得到最新修改的值)。
6、計算機無法進行正確的浮點運算,因為計算機是二進制的,我們在 Java 中可以使用BigDecimal、int或者long進行浮點運算,這樣可以得到準(zhǔn)確的結(jié)果。
7、不要使用字符串連接操作符來連接字符串,除非性能無關(guān)緊要,否則使用StringBuffer中的append方法,或者使用更好的StringBuilder。
?(通常應(yīng)該優(yōu)先使用 StringBuilder 類,因為它支持所有相同的操作,但由于它不執(zhí)行同步,所以速度更快)。
8、添加join后當(dāng)前線程必須要等待該線程結(jié)束后在執(zhí)行,也就是將該線程加入到當(dāng)前線程運行周期之內(nèi)
9、如果不想被惡意攻擊,請使用私有的對象監(jiān)視器。永遠(yuǎn)不要使用線程組ThreadGroup。
10、serialVersionUID 表示一個可序列化的類的版本信息,我們應(yīng)該總是提供一個手動的serialVersionUID,而不是由系統(tǒng)自動生成。這樣可以保證
?類的兼容性和節(jié)省略微的性能開銷。
11、應(yīng)該總是實現(xiàn)自定義的序列化,除非一個對象的物理結(jié)構(gòu)和邏輯結(jié)構(gòu)式一樣的,即使是這樣我們最好也用自定義的序列化,提供一個readObject方法來
?保證約束關(guān)系和安全性。
12、為了實現(xiàn)序列化的Singleton,那么我們應(yīng)當(dāng)提供一個readResolve方法。
13、從本質(zhì)上來講,readResolve方法將readObject從事實上的公有構(gòu)造函數(shù)變成事實上的公有靜態(tài)工廠(針對于反序列化是產(chǎn)生的對象)。??
posted on 2009-11-04 20:51 vagasnail 閱讀(243) 評論(0) 編輯 收藏 所屬分類: Java