java基本數(shù)據(jù)類(lèi)型有哪些 把string當(dāng)enum用,有性能損失嗎?
把string當(dāng)enum用,有性能損失嗎?是的。以C語(yǔ)言為例,在內(nèi)存中創(chuàng)建一個(gè)字符串至少需要存儲(chǔ)一個(gè)字符數(shù)組,因?yàn)樗枰鎯?chǔ)結(jié)束標(biāo)識(shí)符;而枚舉實(shí)際上是一種結(jié)構(gòu),枚舉項(xiàng)可以定義為整數(shù),這比字符串存儲(chǔ)更方
把string當(dāng)enum用,有性能損失嗎?
是的。
以C語(yǔ)言為例,在內(nèi)存中創(chuàng)建一個(gè)字符串至少需要存儲(chǔ)一個(gè)字符數(shù)組,因?yàn)樗枰鎯?chǔ)結(jié)束標(biāo)識(shí)符;而枚舉實(shí)際上是一種結(jié)構(gòu),枚舉項(xiàng)可以定義為整數(shù),這比字符串存儲(chǔ)更方便、更便宜。
此外,如果字符串用作枚舉,則字符串很容易被錯(cuò)誤寫(xiě)入,并且枚舉被定義為數(shù)字常量。編譯器在編譯時(shí)容易發(fā)現(xiàn)錯(cuò)誤,并提示開(kāi)發(fā)人員及時(shí)改正,易于維護(hù)。
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)單。