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 閱讀(136) | 評論 (0)編輯 收藏

          2008年9月19日

           ImageDescriptor temp = ImageDescriptor.createFromURL(url);

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

          posted @ 2008-09-19 12:38 jr4e 閱讀(148) | 評論 (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 閱讀(189) | 評論 (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 閱讀(303) | 評論 (1)編輯 收藏

          2008年9月1日

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

          posted @ 2008-09-01 14:53 jr4e 閱讀(122) | 評論 (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 閱讀(208) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 句容市| 泸州市| 土默特左旗| 龙游县| 怀宁县| 镇巴县| 广饶县| 玉林市| 晋州市| 日照市| 黑水县| 达州市| 麟游县| 丰原市| 定边县| 佛坪县| 年辖:市辖区| 漯河市| 上高县| 沭阳县| 兰坪| 大姚县| 汉寿县| 尤溪县| 陇西县| 南充市| 黄山市| 荔波县| 石楼县| 武山县| 湖口县| 靖远县| 盱眙县| 马关县| 淮安市| 新田县| 得荣县| 盐亭县| 白银市| 都兰县| 延庆县|