国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
java 節(jié)省內(nèi)存
  • 1.少new對(duì)象,能單例盡量單例吧,或者static方法也行 
  • 2.盡量少在session里放東西,盡量放request里吧
  • 3.加載附件、文件之類(lèi)的時(shí)候,不要一次性把整個(gè)附件都加載到內(nèi)存,要用緩存(就是用byte[]),或者那些個(gè)什么BufferedStream之類(lèi)的 
  • 4.大的XML文件用SAX解析,不要用DOM解析 
  • 5.部署在同一臺(tái)服務(wù)器上的不同應(yīng)用,所引用的第三方類(lèi)庫(kù)(比如common*.jar,struts.jar,spring.jar),盡量引用同一份,不要每個(gè)應(yīng)用的lib下都放上10幾M的第三方類(lèi)庫(kù),大多數(shù)都是重復(fù)的 
    還有啥?暫時(shí)就想到這么多
  • 少用+號(hào)連接字符串使用。減少臨時(shí)變量。 
  • 正確的使用javabean的生命周期.
  • 基于數(shù)據(jù)庫(kù)端的分頁(yè)技術(shù)。
  • 大批量數(shù)據(jù)采用JDBC手工處理或存儲(chǔ)過(guò)程處理。
  • 數(shù)據(jù)庫(kù)是J2EE的一個(gè)性能瓶頸,任何時(shí)候都要小心。

//////////////////////////////////////////////////////////////////////////////////////////////////////

 

個(gè)人總結(jié)
1.盡量使用StringBuffer代替string
2.對(duì)頻繁使用的對(duì)象采用對(duì)象池技術(shù),http://commons.apache.org/pool/
   org.apache.commons.pool.PoolableObjectFactory
     |--makeObject()       創(chuàng)建對(duì)象
     |--destroyObject(Object arg0) 銷(xiāo)毀池中對(duì)象
   


import org.apache.commons.pool.impl.GenericObjectPool;

/**
* @author an_chuantong
*/

public class ObjectPool {

private final static org.apache.commons.pool.ObjectPool pool = new GenericObjectPool(new PooledObjectFactory(), -1);

/**
   *找出池中一個(gè)對(duì)象
   */
public static Object borrowObject() throws Exception {
   return pool.borrowObject();
}

/**
   *對(duì)象使用完畢后放回池中
   */
public static void returnObject(Object obj) throws Exception {
   pool.returnObject(obj);
}

}


3.保證每個(gè)IO操作,connection及時(shí)關(guān)閉,做到何處打開(kāi)何處關(guān)閉
4.盡量少new重復(fù)對(duì)象,少在循環(huán)里new對(duì)象
5.對(duì)于util,help等輔助類(lèi)和方法,盡量使用靜態(tài)方法和單子模式

 //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

 

  Java做的系統(tǒng)給人的印象是什么?占內(nèi)存!說(shuō)道這句話就會(huì)有N多人站出來(lái)為java辯護(hù),并舉出一堆的性能測(cè)試報(bào)告來(lái)證明這一點(diǎn)。

  其實(shí)從理論上來(lái)講java做的系統(tǒng)并不比其他語(yǔ)言開(kāi)發(fā)出來(lái)的系統(tǒng)更占用內(nèi)存,那么為什么卻有這么N多理由來(lái)證明它確實(shí)占內(nèi)存呢??jī)蓚€(gè)字,陋習(xí)。

 ?。?)別用new Boolean()。

  在很多場(chǎng)景中Boolean類(lèi)型是必須的,比如JDBC中boolean類(lèi)型的set與get都是通過(guò)Boolean封裝傳遞的,大部分ORM也是用Boolean來(lái)封裝boolean類(lèi)型的,比如:

  ps.setBoolean("isClosed",new Boolean(true));

  ps.setBoolean("isClosed",new Boolean(isClosed));

  ps.setBoolean("isClosed",new Boolean(i==3));

  通常這些系統(tǒng)中構(gòu)造的Boolean實(shí)例的個(gè)數(shù)是相當(dāng)多的,所以系統(tǒng)中充滿了大量Boolean實(shí)例小對(duì)象,這是相當(dāng)消耗內(nèi)存的。Boolean類(lèi)實(shí)際上只要兩個(gè)實(shí)例就夠了,一個(gè)true的實(shí)例,一個(gè)false的實(shí)例。

  Boolean類(lèi)提供兩了個(gè)靜態(tài)變量:

  public static final Boolean TRUE = new Boolean(true);

  public static final Boolean FALSE = new Boolean(false);

  需要的時(shí)候只要取這兩個(gè)變量就可以了,

  比如:

  ps.setBoolean("isClosed",Boolean.TRUE);

  那么象2、3句那樣要根據(jù)一個(gè)boolean變量來(lái)創(chuàng)建一個(gè)Boolean怎么辦呢?可以使用Boolean提供的靜態(tài)方法: Boolean.valueOf()

  比如:

  ps.setBoolean("isClosed",Boolean.valueOf(isClosed));

  ps.setBoolean("isClosed",Boolean.valueOf(i==3));

  因?yàn)関alueOf的內(nèi)部實(shí)現(xiàn)是:return (b ? TRUE : FALSE);

  所以可以節(jié)省大量?jī)?nèi)存。相信如果Java規(guī)范直接把Boolean的構(gòu)造函數(shù)規(guī)定成private,就再也不會(huì)出現(xiàn)這種情況了。

 ?。?)別用new Integer。

  和Boolean類(lèi)似,java開(kāi)發(fā)中使用Integer封裝int的場(chǎng)合也非常多,并且通常用int表示的數(shù)值通常都非常小。SUN SDK中對(duì)Integer的實(shí)例化進(jìn)行了優(yōu)化,Integer類(lèi)緩存了-128到127這256個(gè)狀態(tài)的Integer,如果使用Integer.valueOf(int i),傳入的int范圍正好在此內(nèi),就返回靜態(tài)實(shí)例。這樣如果我們使用Integer.valueOf代替new Integer的話也將大大降低內(nèi)存的占用。如果您的系統(tǒng)要在不同的SDK(比如IBM SDK)中使用的話,那么可以自己做了工具類(lèi)封裝一下,比如IntegerUtils.valueOf(),這樣就可以在任何SDK中都可以使用這種特性。

 ?。?)用StringBuffer代替字符串相加。這個(gè)我就不多講了,因?yàn)橐呀?jīng)被人講過(guò)N次了。我只想將一個(gè)不是笑話的笑話,我在看國(guó)內(nèi)某“著名”java開(kāi)發(fā)的WEB系統(tǒng)的源碼中,竟然發(fā)現(xiàn)其中大量的使用字符串相加,一個(gè)拼裝SQL語(yǔ)句的方法中竟然最多構(gòu)造了將近100個(gè)string實(shí)例。無(wú)語(yǔ)中!

 ?。?)過(guò)濫使用哈希表,有一定開(kāi)發(fā)經(jīng)驗(yàn)的開(kāi)發(fā)人員經(jīng)常會(huì)使用hash表(hash表在JDK中的一個(gè)實(shí)現(xiàn)就是HashMap)來(lái)緩存一些數(shù)據(jù),從而提高系統(tǒng)的運(yùn)行速度。比如使用HashMap緩存一些物料信息、人員信息等基礎(chǔ)資料,這在提高系統(tǒng)速度的同時(shí)也加大了系統(tǒng)的內(nèi)存占用,特別是當(dāng)緩存的資料比較多的時(shí)候。其實(shí)我們可以使用操作系統(tǒng)中的緩存的概念來(lái)解決這個(gè)問(wèn)題,也就是給被緩存的分配一個(gè)一定大小的緩存容器,按照一定的算法淘汰不需要繼續(xù)緩存的對(duì)象,這樣一方面會(huì)因?yàn)檫M(jìn)行了對(duì)象緩存而提高了系統(tǒng)的運(yùn)行效率,同時(shí)由于緩存容器不是無(wú)限制擴(kuò)大,從而也減少了系統(tǒng)的內(nèi)存占用?,F(xiàn)在有很多開(kāi)源的緩存實(shí)現(xiàn)項(xiàng)目,比如ehcache、oscache等,這些項(xiàng)目都實(shí)現(xiàn)了FIFO、MRU等常見(jiàn)的緩存算法。

 ?。?)避免過(guò)深的類(lèi)層次結(jié)構(gòu)和過(guò)深的方法調(diào)用。因?yàn)檫@兩者都是非常占用內(nèi)存的(特別是方法調(diào)用更是堆棧空間的消耗大戶)。

  (6)變量只有在用到它的時(shí)候才定義和實(shí)例化。

 ?。?)盡量避免使用static變量,類(lèi)內(nèi)私有常量可以用final來(lái)代替。



 

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
總結(jié)Java標(biāo)準(zhǔn)類(lèi)庫(kù)中類(lèi)型相互轉(zhuǎn)化的方法
深入剖析Java中的裝箱和拆箱
findBug 錯(cuò)誤修改指南
Java到底是不是一種純面向?qū)ο笳Z(yǔ)言?
Java中的裝箱與拆箱
為什么阿里巴巴Java開(kāi)發(fā)手冊(cè)中強(qiáng)制要求整型包裝類(lèi)對(duì)象值用 equals 方法比較?
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服