Java中的享元设计模式,涨姿势了!
首先來看一段代碼:
public?class?ShareTest?{public?static?void?main(String[] args)?{Integer a =?127;Integer b =?127;System.out.println(a==b);Integer c =?128;Integer d =?128;System.out.println(c==d);} }運行結(jié)果為:true false
為什么會出現(xiàn)這種情況呢?我們來從源代碼中分析一下,首先Integer a = 127這行代碼調(diào)用的是Integer中的valueOf方法,我們來看看這個方法的源碼:
public?static?Integer?valueOf(int?i)?{assert?IntegerCache.high >=?127;if?(i >= IntegerCache.low && i <= IntegerCache.high)return?IntegerCache.cache[i + (-IntegerCache.low)];return?new?Integer(i); }其中IntegerCache就是Integer中的一個內(nèi)部類,從這段代碼中我們可以看出,當(dāng)我的參數(shù)i的范圍在low和high之間時,會直接返回這個內(nèi)部類中的一個數(shù)組中對應(yīng)的值,否則會創(chuàng)建一個新的對象。
那么我們再來看你看這個數(shù)組是怎么創(chuàng)建的:
private?static?class?IntegerCache?{static?final?int?low = -128;static?final?int?high;static?final?Integer cache[];static?{// high value may be configured by propertyint?h =?127;String integerCacheHighPropValue =sun.misc.VM.getSavedProperty("java.lang.Integer.IntegerCache.high");if?(integerCacheHighPropValue !=?null) {int?i = parseInt(integerCacheHighPropValue);i = Math.max(i,?127);// Maximum array size is Integer.MAX_VALUEh = Math.min(i, Integer.MAX_VALUE - (-low) -1);}high = h;cache =?new?Integer[(high - low) +?1];int?j = low;for(int?k =?0; k < cache.length; k++)cache[k] =?new?Integer(j++);}private?IntegerCache()?{} }由這段代碼我們可以知道,這個內(nèi)部類在初始化的時候創(chuàng)建了一個數(shù)組,并且這個數(shù)組的長度為 (high-low+1),然后遍歷循環(huán),創(chuàng)建了從-128到127這256個Integer對象,并將它們放入到這個數(shù)組中。
另外,推薦大家關(guān)注微信公眾號:Java技術(shù)棧,在后臺回復(fù):設(shè)計模式,可以獲取我整理的 N 篇最新設(shè)計模式教程,都是干貨。
所以當(dāng)我們在調(diào)用valueOf的時候,如果值得范圍是在128到127之間,那么是不會創(chuàng)建新的對象的,但是如果超過了這個范圍,那么就會創(chuàng)建姓的對象。這就是之前代碼運行結(jié)果的原因。
到了這里,享元模式的核心思想已經(jīng)漸漸清晰了,其實就是將一些常用的對象緩存起來,在使用的時候直接拿過來使用,不必創(chuàng)建新的對象,這個省去了創(chuàng)建對象時消耗的資源,也省去了GC在回收這些垃對象時消耗的資源。
在我們?nèi)粘i_發(fā)中,享元模式還是比較常見的,最典型的就是池技術(shù),例如服務(wù)器的線程池,JDBC的連接池,這些都是享元模式的很好的體現(xiàn),當(dāng)然,常量池也是享元模式思想。
作者:Mazin
https://my.oschina.net/u/3441184/blog/886337
總結(jié)
以上是生活随笔為你收集整理的Java中的享元设计模式,涨姿势了!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 蚂蚁金服二面:面试官问我零拷贝的实现原理
- 下一篇: 动图 + 源码,演示 Java 中常用数