枚舉單例模式寫(xiě)法 Java單例模式簡(jiǎn)單嗎?
Java單例模式簡(jiǎn)單嗎?Java singleton說(shuō)起來(lái)很簡(jiǎn)單,很多初學(xué)者也認(rèn)為它很簡(jiǎn)單,但是如果你深入思考,你會(huì)發(fā)現(xiàn)它不是那么簡(jiǎn)單。單實(shí)例需要考慮多線程并發(fā)訪問(wèn)的問(wèn)題,這將變得更加復(fù)雜。如何保證線
Java單例模式簡(jiǎn)單嗎?
Java singleton說(shuō)起來(lái)很簡(jiǎn)單,很多初學(xué)者也認(rèn)為它很簡(jiǎn)單,但是如果你深入思考,你會(huì)發(fā)現(xiàn)它不是那么簡(jiǎn)單。
單實(shí)例需要考慮多線程并發(fā)訪問(wèn)的問(wèn)題,這將變得更加復(fù)雜。如何保證線程安全?常用的方法是使用DCL(double check lock)單例。實(shí)現(xiàn)代碼如下:
這里要特別注意。在實(shí)例之前,應(yīng)該添加volatile修飾符。為什么添加此修飾符?這涉及到CPU底層的一些知識(shí)。簡(jiǎn)言之,當(dāng)CPU底層執(zhí)行指令時(shí),它會(huì)對(duì)不同的指令重新排序。java代碼中的一行代碼可能是CPU底層的多條指令。如果發(fā)生重新排序,則在單例對(duì)象的實(shí)例化過(guò)程中,可能會(huì)返回處于半初始化狀態(tài)的對(duì)象。那么由當(dāng)前線程獲得的實(shí)例與由其他線程獲得的完全初始化的對(duì)象是不同的。Volatile修飾符可以防止CPU底層對(duì)這行代碼的相關(guān)指令重新排序,直到對(duì)象完全初始化,從而確保多個(gè)線程訪問(wèn)singleton并返回相同的對(duì)象。
因此,看似簡(jiǎn)單的問(wèn)題并不簡(jiǎn)單。
什么是單例模式,最好寫(xiě)一個(gè)簡(jiǎn)單的單例模式的實(shí)現(xiàn),謝謝?
單例模式,即一個(gè)類(lèi)只能有一個(gè)實(shí)例。無(wú)論何時(shí),誰(shuí)請(qǐng)求,都是同一個(gè)實(shí)例。
單例模式,每種語(yǔ)言都有自己的實(shí)現(xiàn)方式,這里我以Java為例。實(shí)現(xiàn)單例的方法有很多。如果您想要最簡(jiǎn)單和最完美的實(shí)現(xiàn),請(qǐng)參閱以下代碼。這是我?guī)滋烨敖o朋友解釋辛格爾頓時(shí)寫(xiě)的。
Java collection framework的作者Joshua Bloch在《有效的Java》一書(shū)中推薦了這種寫(xiě)作方式枚舉型的單元素已成為實(shí)現(xiàn)“單例”的最佳途徑。
看起來(lái)不簡(jiǎn)單嗎?單例枚舉非常簡(jiǎn)單,可以保證多線程并發(fā)訪問(wèn)的安全性,防止序列化和反射。