眾所周知, 在Java中, String類是不可變的。那么到底什么是不可變的對象呢? 可以這樣認為:如果一個對象,在它創建完成之后,不能再改變它的狀態,那么這個對象就是不可變的。不能改變狀態的意思是,不能改變對象內的成員變量,包括基本數據類型的值不能改變,引用類型的變量不能指向其他的對象,引用類型 ...
一 案例場景 遇到過這樣的場景,在定義一個static修飾的Map時,使用了大量的put 方法賦值,就類似這樣 當時,我就在想,是否可以進一步優化下,使得代碼看起來更為優雅些,然后,就發現了Google Guava里的有一個類ImmutableMap,通過這個類可以實現類似建造者模式的鏈式編程,優化后的效果,如下: 二 ImmutableMap源碼分析 那么,這個ImmutableMap究竟是如何 ...
2021-06-22 22:35 0 205 推薦指數:
眾所周知, 在Java中, String類是不可變的。那么到底什么是不可變的對象呢? 可以這樣認為:如果一個對象,在它創建完成之后,不能再改變它的狀態,那么這個對象就是不可變的。不能改變狀態的意思是,不能改變對象內的成員變量,包括基本數據類型的值不能改變,引用類型的變量不能指向其他的對象,引用類型 ...
createTempDir()之后就沒有什么有意思的函數了,基本上都是對Java IO函數操作的聚合,只看一個simplifyPath() 最后附上各函數功能的解釋 下文來自: http://blog.csdn.net/husc2009/article/details ...
看上面一段代碼,我們會發生疑惑:為什么通過字符串常量實例化的String類型對象是一樣的,而通過new所創建String對象卻不一樣呢?且看下面分解。 1. 數據存儲區 String是一個比較 ...
一、概述 TreeMap是基於紅黑樹實現的。由於TreeMap實現了java.util.sortMap接口,集合中的映射關系是具有一定順序的,該映射根據其鍵的自然順序進行排序或者根據創建映射時提供的Comparator進行排序,具體取決於使用的構造方法。另外TreeMap中不允許鍵對象 ...
一、ArrayList簡介 ArrayList是可以動態增長和縮減的索引序列,它是基於數組實現的List類。 該類封裝了一個動態再分配的Object[]數組,每一個類對象都有一個capac ...
一、HashMap簡介 HashMap是基於哈希表的Map接口實現的,它存儲的是內容是鍵值對<key,value>映射。此類不保證映射的順序,假定哈希函數將元素適當的分布在各桶之間,可為基本操作(get和put)提供穩定的性能。 ps:本文中的源碼來自jdk1.8.0_45 ...
一、HashMap簡介 1.1、HashMap概述 HashMap是基於哈希表的Map接口實現的,它存儲的是內容是鍵值對<key,value>映射。此類不保證映射的順序,假定哈希函 ...
前言 前面一篇我們分析了ArrayList的源碼,這一篇分享的是LinkedList。我們都知道它的底層是由鏈表實現的,所以我們要明白什么是鏈表? 一、LinkedList簡介 1.1、LinkedList概述 LinkedList是一種可以在任何位置進行高效地插入和移除 ...