java單例模式應(yīng)用場(chǎng)景 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)單。