首先關(guān)于系統(tǒng)優(yōu)化可以分為
1.設(shè)計(jì)優(yōu)化
2.代碼優(yōu)化
3.數(shù)據(jù)庫(kù)優(yōu)化
大致分為這三個(gè)方面的優(yōu)化,當(dāng)然在針對(duì)這個(gè)系統(tǒng)的優(yōu)化之前的前提是明確系統(tǒng)需求。
今天最要針對(duì)設(shè)計(jì)優(yōu)化上一些講解和心得筆記耻瑟。當(dāng)然談到設(shè)計(jì),我們首先想到的是設(shè)計(jì)原則和23種設(shè)計(jì)模式供嚎。
常見(jiàn)代碼中設(shè)計(jì)到的幾種設(shè)計(jì)模式
1.單例模式:保證系統(tǒng)中只有一個(gè)實(shí)例化對(duì)象吧雹。
2.代理模式
3.享元模式
4.裝飾者模式
5.觀察者模式
6.Value Object 模式
首先,我們來(lái)談?wù)剢卫J秸撕浚瓤匆欢未a
/**
* Created by Darker on 15/6/11.
*/
public class Singleton{
private static Singleton ourInstance=newSingleton();
public static Singleton getInstance(){
return ourInstance;
}
private Singleton(){
System.out.println("init Singleton");
}
}
上面的代碼是莫瞬,創(chuàng)建單例模式的常見(jiàn)方式,也是最容易上手的代碼郭蕉,但是它唯一的缺點(diǎn)就是在JVM 加載類的時(shí)候搁骑,就需要進(jìn)行加載,時(shí)間太慢诺祸,直接影響到系統(tǒng)功能揣钦,所以要考慮到延遲加載。
然后涨岁,再來(lái)看看一段代碼
/**
* Created by Darker on 15/6/11.
*/
public class Singleton{
private static Singleton ourInstance;
public static ?Singleton getInstance(){
if(ourInstance==null){
ourInstance=newSingleton();
}
return ourInstance;
}
private Singleton(){
System.out.println("init Singleton");
}
}
當(dāng)你看到這段代碼的時(shí)候拐袜,你肯定覺(jué)得這種方式和上面的static 方式?jīng)]什么區(qū)別,無(wú)非只是加了一個(gè)判斷是否為null梢薪,確實(shí)做到延遲加載蹬铺,喲西,等等…我們是不是忘記了多線程下秉撇,這段代碼就會(huì)出問(wèn)題甜攀,線程并行進(jìn)行,判斷為null畜疾,有可能就會(huì)出現(xiàn)多個(gè)instance赴邻。于是我們就線到同步關(guān)鍵字,synchronized啡捶。于是有了下面的代碼.
/**
* Created by Darker on 15/6/11.
*/
public class Singleton{
private static Singleton ourInstance;
public static synchronized Singleton getInstance(){
if(ourInstance==null){
ourInstance=newSingleton();
}
return ourInstance;
}
private Singleton(){
System.out.println("init Singleton");
}
}
nice 袄蚜病!瞎暑,是不是很帥.完全解決多線程下的問(wèn)題彤敛,保證只有一個(gè)單例与帆。等等,所謂的優(yōu)化墨榄,是從空間和時(shí)間上進(jìn)行用戶啊玄糟,現(xiàn)在確實(shí)能保證空間,功能上沒(méi)有差錯(cuò)袄秩,但是耗時(shí)阵翎?? 通過(guò)測(cè)試之剧,static 單例郭卫,和 同步單例,在開(kāi)啟5個(gè)線程的同時(shí)耗時(shí)相差2個(gè)數(shù)量級(jí)背稼,所以這段代碼以耗時(shí)為代價(jià)贰军,完成延遲加載,感覺(jué)有點(diǎn)得不償失蟹肘。說(shuō)明還有更強(qiáng)大的單例代碼設(shè)計(jì)词疼。于是便有了下面一段代碼.
/**
* Created by Darker on 15/6/11.
*/
public class Singleton{
private Singleton(){
System.out.println("init Singleton");
}
private static class SingletonHodler{
private static Singleton instance=newSingleton();public static Singleton getInstance(){
return SingletonHodler.instance;
}
}
}
哇,強(qiáng)大的內(nèi)部類帘腹,竟然出現(xiàn)在這段代碼中贰盗,這樣的實(shí)現(xiàn)方式,很棒吧竹椒,使用內(nèi)部類來(lái)維護(hù)單例的實(shí)例童太,當(dāng)Singleton被加載時(shí)米辐,其中內(nèi)部類并不會(huì)被加載胸完,只有當(dāng)調(diào)用getInstance()方法的時(shí)候,才能被加載翘贮,等等延遲加載是不是很屌的就解決了赊窥,對(duì)的。那么多線程下狸页,這代碼管用么锨能?private static Singleton instance=new Singleton();這段代碼,和第一種是一樣的芍耘,對(duì)址遇,這就是天生對(duì)多線程友好,所以也解決了斋竞。多線程同步的問(wèn)題….nice 啊倔约。
最后,當(dāng)然..你用反射機(jī)制 也可以new出多個(gè)實(shí)例坝初,但是這么極端…你就有點(diǎn)過(guò)啦..