posts - 6, comments - 1, trackbacks - 0, articles - 0

          2008年9月23日

          public class NameManager implements INameManager {
                 private Set namePool = new HashSet();
                

              public String generateName(String nameType) {

                  if (!namePool.contains(nameType)) {
                 namePool.add(nameType);
                  return nameType;
            }

            int i = 1;
            while (namePool.contains(nameType + i)) {
             i++;
            }
            namePool.add(nameType + i);
            return nameType + i;
           }


          posted @ 2008-09-23 11:44 jr4e 閱讀(138) | 評論 (0)編輯 收藏

          2008年9月19日

           ImageDescriptor temp = ImageDescriptor.createFromURL(url);

           org.eclipse.swt.graphics.Image image = temp.createImage();

          posted @ 2008-09-19 12:38 jr4e 閱讀(150) | 評論 (0)編輯 收藏

          2008年9月18日

          1.通過獲得當前激活的editor來得到NameManager
          IEditorPart editor = PlatformUI.getWorkbench()
              .getActiveWorkbenchWindow().getActivePage().getActiveEditor();
            ReportEditor reportEditor = null;
            if (editor instanceof ReportEditor)
             reportEditor = (ReportEditor) editor;

            String dsDisplayName = reportEditor.getDisplaynameByQDSName(table
              .getDataSet());
            INameManager nameManager = ((ReportEditorInput) reportEditor
              .getEditorInput()).getNameManager();
          2.獲得editPart的祖先的方法
          GefUtilities.getAncestorOfClass(Class c, EditPart editPart)
          public static EditPart getAncestorOfClass(Class c, EditPart editPart)

          3.獲得模型祖先的方法
          ModelUtilities.getAncestorOfClass(Class c, EObject model));
          public static EObject getAncestorOfClass(Class c, EObject model)

          posted @ 2008-09-18 18:55 jr4e 閱讀(190) | 評論 (0)編輯 收藏

          2008年9月9日

          Eclipse的Wizard是由一系列WizardPage組成的。缺省情況下,WizardDialog在初始化的時候就會調用每個WizardPage的createControl()方法來布局這些WizardPage,這是為了方便決定WizardDialog窗口的大小。但如果某個WizardPage里的控件是需要動態生成的,例如,用戶在Page1里輸入一個整數n,Page2里要根據這個整數生成n個文本框,由于Page2的createControl()只有一次被調用的機會,并且在得到n之前就被WizardDialog調用過了,集中布局的方式就為生成Page2的界面帶來了困難。

          和問題的描述比起來,解決的方法簡單很多,只要覆蓋Wizard的createPageControls()方法讓它什么都不要做就可以了
          @Override
          public void createPageControls(Composite pageContainer) {
              
          //super.createPageControls(pageContainer);
          }

          posted @ 2008-09-09 10:15 jr4e 閱讀(304) | 評論 (1)編輯 收藏

          2008年9月1日

          1.用于大小改變,位置改變,以及添加操作-XYLayoutEditPolicy
          2.用于實現菜單,刪除操作-ComponentEditPolicy
          3.用于實現選擇操作 -ResizableEditPolicy

          posted @ 2008-09-01 14:53 jr4e 閱讀(123) | 評論 (0)編輯 收藏

          2008年8月24日

          JAVA體系結構-java虛擬機概述

          最初,Sun公司為java體系定義了4個規范:
          java語言;=》規范了源文件
          class文件格式;
          java API;
          java 虛擬機;

          編譯期,java編譯器(javac)將java源文件編譯成class文件;運行期用戶的class文件和java API的class文件在java虛擬機上協同工作。

          java虛擬機最主要的2個作用是裝載class文件和執行這些class文件所包含的字節碼(bytecode)。
          這決定了java虛擬機的主要2個部件是:
          類裝載器 class loader;
          執行引擎 execution engine;

          顧名思義,類裝載器就是把用戶程序的class和java API里的class裝載到執行引擎,但是它僅僅只選擇真正被用到的class進行裝載。

          執行引擎的任務則是執行class文件中的字節碼。由于class文件格式都遵循一種規范,所以執行引擎是可以有多種不同的方式來實現的。比如它可以是一個解釋器,讀一句字節碼,生成一句機器碼,然后執行之,這是典型的解釋器行為; 它也可以在第一次執行某個方法時,將該方法編譯成機器碼,并緩存起來,下次該方法再被調用時它直接執行緩存的機器碼,這其實是編譯行為。所以必須記住,并不是所有的java虛擬機都是解釋器(interpreter)。

          關于JNI(java native interface)
          通過JNI,java允許你的程序調用任何其他語言寫的方法。然而這樣也將使你失去java平臺無關的優勢。建議只用java實現方法或只調用java API提供的native方法。

          posted @ 2008-08-24 13:38 jr4e 閱讀(210) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 三门峡市| 桃江县| 临安市| 保康县| 大冶市| 大连市| 北票市| 启东市| 临朐县| 怀来县| 沁源县| 叙永县| 和平区| 茌平县| 资阳市| 宣武区| 上杭县| 宝兴县| 永善县| 清新县| 丰城市| 萍乡市| 丰原市| 昭苏县| 铜山县| 石屏县| 尼勒克县| 呼和浩特市| 西平县| 合江县| 从江县| 丁青县| 赞皇县| 清河县| 金门县| 阿克| 新安县| 洛宁县| 乌兰县| 白玉县| 灌云县|