今天早上的Blog大家都看到了,大家的留言我也一一拜讀過(guò)了~感謝 , , , , 等的回復(fù)。
下午反省了一下自己的代碼,得出一下結(jié)論和疑問(wèn),有時(shí)間,請(qǐng)大家再討論一下。
1.反省代碼,整理所有用過(guò)的對(duì)象,特別上查詢完數(shù)據(jù)庫(kù)返回的上萬(wàn)條記錄的結(jié)果集,一一將他們制空,然后再System.gc()看看效果;
2.因?yàn)槭峭ㄓ脭?shù)據(jù)查詢平臺(tái),那么結(jié)果集的展示形式是可以由實(shí)施人員自由定義的,比方說(shuō)字體,顏色,圖片等等,雖然我沒(méi)有使用JFace對(duì)資源封裝的統(tǒng)一標(biāo)準(zhǔn)組件,但是絕對(duì)是在使用完一一做了銷毀處理,我的疑問(wèn)是,我對(duì)資源做了銷毀處理,是不是這部分資源在虛擬機(jī)中的占用空間依舊存在,也就是并沒(méi)有真正的銷毀他們;
這里談?wù)勛约旱膶?shí)踐經(jīng)驗(yàn),如果真的是資源的問(wèn)題,首先出問(wèn)題的還輪不到Javaw,Eclipse馬上就會(huì)出來(lái)叫囂,告訴你沒(méi)有足夠的資源的可以使用,不能創(chuàng)建GC,字體,顏色或者是圖片等等,如果還是不解決,客戶端的GUI馬上就會(huì)變形,變的面目全非~
3.我現(xiàn)在碰到的問(wèn)題還不是內(nèi)存不足,或者內(nèi)存溢出,而是Javaw的內(nèi)存占有再不斷的遞增,并不是某一個(gè)恒定值區(qū)間;
希望大家再次賜教!
最近在公司從事一個(gè)通用的數(shù)據(jù)查詢平臺(tái)的開(kāi)發(fā),是一個(gè)基于Eclipse-RCP的應(yīng)用,項(xiàng)目現(xiàn)在基本進(jìn)入改進(jìn)和修正BUG階段。
但是現(xiàn)在碰到了令人頭疼的問(wèn)題,程序在測(cè)試人員的機(jī)器上跑上半個(gè)多小時(shí),整個(gè)應(yīng)用程序的內(nèi)存會(huì)占到300m以上,如果是做頻繁的大數(shù)據(jù)查詢,內(nèi)存漲的更快。
我加了每分鐘調(diào)用一次System.gc()的線程,唯一的改觀是在Eclipse下面的內(nèi)存進(jìn)度顯示上,會(huì)出現(xiàn)小范圍的減少,但是從任務(wù)管理器中檢視應(yīng)用程序的內(nèi)存,還是居高不下~
Java本身吃內(nèi)存,我能理解,Eclipse-RCP也會(huì)加載大量的東西,我也能理解,大數(shù)據(jù)量的加載更可怕,我更能理解,但是無(wú)論怎么調(diào)用System.gc()都沒(méi)有什么反應(yīng),我就不能理解了~
希望做過(guò)這方面的研究或者應(yīng)用的朋友幫忙解答,或者談?wù)劷?jīng)驗(yàn)~也可以幫助我做一些改善~
我用代碼硬生生的把Eclipse-RCP丑陋的Coolbar替換掉了,但是不爽的是,Viewer上使用的是CTabFolder,而這個(gè)CTabFolder的產(chǎn)生,我沒(méi)有辦法操控,希望有高手指點(diǎn)。
修改代碼如下:
1
package test;
2
3
import org.eclipse.swt.SWT;
4
import org.eclipse.swt.graphics.Point;
5
import org.eclipse.swt.layout.FillLayout;
6
import org.eclipse.swt.widgets.Composite;
7
import org.eclipse.swt.widgets.Shell;
8
import org.eclipse.ui.application.ActionBarAdvisor;
9
import org.eclipse.ui.application.IActionBarConfigurer;
10
import org.eclipse.ui.application.IWorkbenchWindowConfigurer;
11
import org.eclipse.ui.application.WorkbenchWindowAdvisor;
12
import org.eclipse.ui.internal.WindowTrimProxy;
13
import org.eclipse.ui.internal.WorkbenchMessages;
14
import org.eclipse.ui.internal.WorkbenchWindowConfigurer;
15
import org.eclipse.ui.internal.layout.TrimLayout;
16
17
import com.hexapixel.widgets.generic.ColorCache;
18
import com.hexapixel.widgets.ribbon.RibbonTab;
19
import com.hexapixel.widgets.ribbon.RibbonTabFolder;
20
21
public class ApplicationWorkbenchWindowAdvisor extends WorkbenchWindowAdvisor
{
22
23
private TrimLayout defaultLayout;
24
private Composite topComposite;
25
private WindowTrimProxy topCompositeTrim;
26
private Composite pageComposite;
27
28
public ApplicationWorkbenchWindowAdvisor(IWorkbenchWindowConfigurer configurer)
{
29
super(configurer);
30
}
31
32
public ActionBarAdvisor createActionBarAdvisor(IActionBarConfigurer configurer)
{
33
return new ApplicationActionBarAdvisor(configurer);
34
}
35
36
public void preWindowOpen()
{
37
IWorkbenchWindowConfigurer configurer = getWindowConfigurer();
38
configurer.setInitialSize(new Point(400, 300));
39
configurer.setShowCoolBar(false);
40
configurer.setShowStatusLine(false);
41
configurer.setTitle("Hello RCP");
42
}
43
44
@Override
45
public void createWindowContents(Shell shell)
{
46
shell.setBackground(ColorCache.getInstance().getColor(182, 206, 238));
47
// TODO Auto-generated method stub
48
defaultLayout = new TrimLayout();
49
defaultLayout.setSpacing(2, 2, 2, 2);
50
defaultLayout.setMargins(2, 2);
51
shell.setLayout(defaultLayout);
52
53
//topComposite
54
topComposite = new Composite(shell, SWT.None);
55
topComposite.setLayout(new FillLayout(SWT.VERTICAL));
56
topComposite.setBackground(ColorCache.getInstance().getColor(182, 206, 238));
57
58
final RibbonTabFolder ftf = new RibbonTabFolder(topComposite, SWT.NONE);
59
RibbonTab ft0 = new RibbonTab(ftf, "Home");
60
RibbonTab ft1 = new RibbonTab(ftf, "Insert");
61
new RibbonTab(ftf, "Page Layout");
62
new RibbonTab(ftf, "References");
63
64
topCompositeTrim = new WindowTrimProxy(topComposite,"org.eclipse.ui.internal.WorkbenchWindow.topBar", WorkbenchMessages.TrimCommon_Main_TrimName, SWT.NONE, true);
65
66
67
68
69
pageComposite = (Composite) ((WorkbenchWindowConfigurer) getWindowConfigurer()).createPageComposite(shell);
70
setLayoutDataForContents();
71
}
72
73
private void setLayoutDataForContents()
{
74
updateLayoutDataForContents();
75
76
}
77
78
private void updateLayoutDataForContents()
{
79
if (defaultLayout == null)
{
80
return;
81
}
82
defaultLayout.addTrim(SWT.TOP, topCompositeTrim);
83
topComposite.setVisible(true);
84
85
pageComposite.setBackground(ColorCache.getInstance().getColor(182, 206, 238));
86
defaultLayout.setCenterControl(pageComposite);
87
88
}
89
90
}
91
相信嗎,這是SWT做的!這個(gè)就是Nebula項(xiàng)目維護(hù)者的新作~SWT Ribbon~前一段時(shí)間一直把玩的SWT Gantt也是他的作品,非常好用,功能十分強(qiáng)加~
讀過(guò)他的代碼的朋友也許都有感覺(jué),他的代碼思路非常清晰,代碼量不大,但是絲絲入扣,寥寥幾行就能把功能實(shí)現(xiàn)~高手中高手~
再贊一下Nebula的Grid,有了它,我已經(jīng)不再考慮使用Table了~有時(shí)間大家都研究研究吧~
10.1忙七天,呵呵又跟5.1一樣,沒(méi)的休息~沒(méi)辦法,誰(shuí)讓咱們干這行了呢?老大的話就是命令,客戶才不管你是死是活呢~
部門要開(kāi)始新一輪的擴(kuò)張了,第一批進(jìn)來(lái)6個(gè)開(kāi)發(fā)人員,這次又是20個(gè)畢業(yè)生免費(fèi)培訓(xùn),層層篩選最后留10個(gè)。這種招人的方法確實(shí)很有效果~不過(guò)最辛苦的還是我們,每天不但要拼命的趕進(jìn)度,還是給學(xué)生們培訓(xùn)~
這次要好好的給學(xué)生們講講SWT和JFace,好好的給自己培養(yǎng)幾個(gè)得力助手~
10.1結(jié)束了,大家都加油吧~
9月18日IBM放出了醞釀已久的Lotus Symphony來(lái)對(duì)抗微軟,這個(gè)上世紀(jì)八十年代就出現(xiàn)的小子,現(xiàn)在又返老還童了!
今天,趁著加班的事件,網(wǎng)速不錯(cuò),拖了回來(lái),來(lái)感受一下Lotus Symphony的優(yōu)秀,不!應(yīng)該是感受一下Eclipse的優(yōu)秀!
Lotus Symphony是一個(gè)基于Eclipse-RCP的應(yīng)用,不過(guò)啟動(dòng)速度確實(shí)不敢恭維,重要的還是它的界面,確實(shí)可以和Office2007有一拼~、

主啟動(dòng)界面

媲美Word的Lotus Symphony Documents
雖然從功能上Lotus Symphony 和Office還差的很遠(yuǎn),但是我們終于又看到了一個(gè)敢和微軟叫板的產(chǎn)品了~而且還是在Eclipse基礎(chǔ)上構(gòu)建的~這點(diǎn)是讓人興奮的,以后再有人問(wèn)我,Eclipse-RCP有什么成功的案例,我就給他看Lotus Symphony!
此外IBM為L(zhǎng)otus Symphony 還在Eclipse基礎(chǔ)上做了很多的新東西,有有待于慢慢研究~傳說(shuō)是Lotus Symphony 是開(kāi)源的,但是在官方站上并沒(méi)有找到CVS或者SVN地址~這點(diǎn)是讓人無(wú)奈的!
ORM中,一對(duì)多關(guān)系一般都是單向的,簡(jiǎn)單的說(shuō)是孩子們知道自己的父親,父親不知道自己的兒子們,在需要的時(shí)候再去取得自己兒子們~
今天,我們加班對(duì)實(shí)體關(guān)系進(jìn)行有優(yōu)化,出現(xiàn)了一片白癡的兒子~沒(méi)有一個(gè)兒子知道自己的父親,而自己的父親反倒知道自己的孩子們~真可怕!
我們是基于SWT的開(kāi)發(fā),所有對(duì)象取下來(lái),其實(shí)在SWT上全是對(duì)象,什么都可以找到了~不像BS的開(kāi)發(fā),東西取下來(lái),每一次操作都要面向一次數(shù)據(jù),這樣的修改也是很合理的~
總之今天是長(zhǎng)見(jiàn)識(shí)了,白癡的兒子們?nèi)f歲!
使用SWT做開(kāi)發(fā)的朋友,一定要注意~資源是一個(gè)殺手!對(duì)于我們這些無(wú)知的開(kāi)發(fā)人員,使用了資源,不釋放它,比不寫程序或者不提供這個(gè)功能還可怕~因?yàn)樗?jīng)不起考驗(yàn),到了時(shí)間肯定完蛋!
前兩個(gè)天就遇到了這個(gè),同事寫了一個(gè)插件,一次性從數(shù)據(jù)庫(kù)中取得1W以上的數(shù)據(jù)然后組織成樹(shù)表格,顯示給客戶~取得數(shù)據(jù)的速度,樹(shù)組裝的速度,樹(shù)展開(kāi)的速度,都做了反復(fù)的優(yōu)化,一切優(yōu)化完成以后,就宣布完成!但是沒(méi)有測(cè),當(dāng)我連續(xù)打開(kāi)4個(gè)樹(shù)以后,程序就非掉了~
我先加大rcp的啟動(dòng)內(nèi)存,沒(méi)用!瘋狂調(diào)用cg,沒(méi)用!而且這中錯(cuò)誤錯(cuò)的很奇怪,如果是內(nèi)存異常,應(yīng)該是JVM報(bào)出的,但是這次不是,仔細(xì)閱讀異常,竟然是SWT打開(kāi)圖片,顏色,字體的時(shí)候的異常~肯定是資源問(wèn)題了!
因?yàn)橐郧耙恢痹儆肑face的treeviewer組件,所以一直沒(méi)有關(guān)心資源的問(wèn)題~但是1W的數(shù)據(jù),使用的SWT的原生Tree組裝的~而且還用了一些字體~
排查代碼,竟然發(fā)現(xiàn)有字體被new出,但是沒(méi)有釋放~問(wèn)題就出在這里~
調(diào)用了
Font font = new Font (display, "Courier", 10, SWT.NORMAL);
那么就應(yīng)該在不在需要這個(gè)Font的時(shí)候調(diào)用
font.dispose();
兩個(gè)原則:
第一條是"誰(shuí)占用,誰(shuí)釋放",第二條是"父構(gòu)件被銷毀,子構(gòu)件也同時(shí)被銷毀"。
最近一直在忙,忙的不亦樂(lè)乎了~做了很多事情...屬于商業(yè)機(jī)密,所以沒(méi)有辦法一一點(diǎn)出~
終于閑一下,維護(hù)維護(hù)Blog吧~
今天說(shuō)說(shuō)Eclipse3.3國(guó)際化的問(wèn)題,Eclipse-RCP項(xiàng)目做做國(guó)際化的時(shí)候,存在兩個(gè)層面,一個(gè)是控件上的中文,另一個(gè)是Plugin.xml中的中文信息,控件上的中文,沒(méi)有什么可說(shuō)的,用一個(gè)類,加一個(gè)資源文件就可以了~主要的問(wèn)題是Plugin.xml中的中文信息;
根據(jù)各大網(wǎng)站和資料的中描述,Plugin.xml中中文信息用一下方法處理:
1.在Plugin.xml同目錄下新建plugin.properties;
2.將Plugin.xml文件中中文部分替換成%xxxx;
不知道這樣的辦法是不是在Eclipse3.3以前的版本中有用,反正我在Eclipse3.3中,這招沒(méi)有用,PDE可以解析到%XXX的內(nèi)容,但是啟動(dòng)應(yīng)用程序以后沒(méi)有任何效果,所有修改的地方都顯示為%XXX了~
解決辦法就是:
請(qǐng)?jiān)诓寮?nbsp;MANIFEST.MF 文件后面添加上 Bundle-Localization: plugin 和一個(gè)回車應(yīng)該可以解決你的問(wèn)題。
在MF中多加一句就好了~
遇到同類問(wèn)題的朋友注意了~