java基本數(shù)據(jù)類型有哪些 把string當enum用,有性能損失嗎?
把string當enum用,有性能損失嗎?是的。以C語言為例,在內(nèi)存中創(chuàng)建一個字符串至少需要存儲一個字符數(shù)組,因為它需要存儲結(jié)束標識符;而枚舉實際上是一種結(jié)構(gòu),枚舉項可以定義為整數(shù),這比字符串存儲更方
把string當enum用,有性能損失嗎?
是的。
以C語言為例,在內(nèi)存中創(chuàng)建一個字符串至少需要存儲一個字符數(shù)組,因為它需要存儲結(jié)束標識符;而枚舉實際上是一種結(jié)構(gòu),枚舉項可以定義為整數(shù),這比字符串存儲更方便、更便宜。
此外,如果字符串用作枚舉,則字符串很容易被錯誤寫入,并且枚舉被定義為數(shù)字常量。編譯器在編譯時容易發(fā)現(xiàn)錯誤,并提示開發(fā)人員及時改正,易于維護。
Java單例模式簡單嗎?
Java singleton說起來很簡單,很多初學者也認為它很簡單,但是如果你深入思考,你會發(fā)現(xiàn)它不是那么簡單。
單實例需要考慮多線程并發(fā)訪問的問題,這將變得更加復雜。如何保證線程安全?常用的方法是使用DCL(double check lock)單例。實現(xiàn)代碼如下:
這里要特別注意。在實例之前,應該添加volatile修飾符。為什么添加此修飾符?這涉及到CPU底層的一些知識。簡言之,當CPU底層執(zhí)行指令時,它會對不同的指令重新排序。java代碼中的一行代碼可能是CPU底層的多條指令。如果發(fā)生重新排序,則在單例對象的實例化過程中,可能會返回處于半初始化狀態(tài)的對象。那么由當前線程獲得的實例與由其他線程獲得的完全初始化的對象是不同的。Volatile修飾符可以防止CPU底層對這行代碼的相關(guān)指令重新排序,直到對象完全初始化,從而確保多個線程訪問singleton并返回相同的對象。
因此,看似簡單的問題并不簡單。