posts - 241,  comments - 116,  trackbacks - 0

          在做網(wǎng)絡(luò)監(jiān)控系統(tǒng) 的性能 測試 時,出現(xiàn)了內(nèi)存 泄露的問題,困擾了很久,現(xiàn)在終于算是解決了,但是根本原因尚不明確,拿出來大家討論下,看看能不能完美解決~

          這個問題奇怪的地方在于是Java 進(jìn)程內(nèi)存泄露,而不是平常的JVM內(nèi)存泄露,用Jprofile等工具 也無法看出問題所在。

          測試代碼 如下:

           1  System.loadLibrary( " test1 " );
           2  
           3           int  threadPoolSize  =   400 ;
           4          ExecutorService service  =  Executors.newFixedThreadPool(threadPoolSize);
           5  
           6           for  ( int  i  =   0 ; i  <   400 ; i ++ ) {
           7              service.submit( new  Runnable() {
           8                   public   void  run() {
           9                       while  ( true ) {
          10                           try  {
          11                              Thread t  =   new  Thread();
          12                              t.start();
          13                              Thread.sleep( 100 );
          14                          }  catch  (Exception e) {
          15                              e.printStackTrace();
          16                          }
          17                      }
          18                  }
          19              });
          20          }

           

          說明:此段代碼所做的工作就是加載一個dll,然后不斷的啟動線程(線程什么也不做,直接終止)。
          注:線程池只是為了加速問題復(fù)現(xiàn),無其他用處。

          現(xiàn)象:
          1.如果不加載dll,只不斷的啟動線程,Java進(jìn)程內(nèi)存正常,不會一直增長。
          2.如果加載附件中test1的dll,Java進(jìn)程內(nèi)存會一直增長。集裝箱運(yùn)費(fèi)
          3.如果加載附件中test2的dll(需要安裝C++運(yùn)行環(huán)境vcredist_x86),Java進(jìn)程內(nèi)存正常,不會一直增長。

          dll說明:
          dll的工程源碼在附件中,test1和test2的區(qū)別只在于編譯選項(xiàng),如附件:test1選擇的是“使用標(biāo)準(zhǔn)Windows 庫”或“在靜態(tài)庫中使用MFC”,test2選擇的是“在共享DLL中使用MFC”
          此dll工程的特點(diǎn)在于使用了jni,并引入了mfc頭文件 【#include <afxwin.h>】,如果不引入mfc頭文件則不會引起內(nèi)存泄漏WiiU中文站

          目前此問題的根本原因尚不明確,懷疑是jdk的bug (使用最新的jdk1.6.0.23也沒用),不知道大家有什么想法嗎?歡迎大家討論~

          /Files/cyj86/dll工程.rar
          /Files/cyj86/test1.rar
          /Files/cyj86/test2.rar
          /Files/cyj86/vcredist_x86.rar
          /Files/cyj86/opt.png


          posted on 2011-06-16 09:55 墻頭草 閱讀(760) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          人人游戲網(wǎng) 軟件開發(fā)網(wǎng) 貨運(yùn)專家
          主站蜘蛛池模板: 亚东县| 伊吾县| 枣庄市| 雷州市| 武定县| 电白县| 朝阳县| 光山县| 永仁县| 深泽县| 敦化市| 南华县| 个旧市| 吴旗县| 新源县| 雅安市| 岳阳市| 邵武市| 方山县| 渭源县| 盐池县| 乐陵市| 南靖县| 巴林左旗| 图片| 德江县| 宝山区| 拉萨市| 营口市| 肇庆市| 和静县| 同江市| 南岸区| 丹巴县| 泸西县| 云阳县| 惠水县| 双桥区| 沙洋县| 商丘市| 嘉鱼县|