zoukankan      html  css  js  c++  java
  • Eclipse plugin插件开发 NoClassDefFoundError

    Eclipse的每一个plugin都有属于自己的类加载器,这是OSGI架构的基础,每一个plugin项目都是一个bundle,独立运行在各自的运行环境里面,这就造成了开发时和运行时的不同。


    Eclipse插件开发,切记不要随便引入别的plugin工程到自己的classPath中,正确的做法应该是引用插件依赖。下面就分几种情况来讲一下这个Eclipse插件项目运行时报错:NoClassDefFoundError。


    首先引用http://www.blogjava.net/Jeffery001/archive/2008/10/14/234166.html所说的三种情况,最后我谈下我出现的第四种情况,就是前三种解决办法都不生效的时候,看下第4种。


    Eclipse插件开发对于Jar包的引用主要有三种原因:

    1. 插件引用第三方包(普通的jar包或者类文件,不是插件)。

    a)开发环境引用配置,在prject -> properties -> Java build path中设置。

    b)运行环境引用配置,在plugin manifest编辑器的Runtime选项卡下的classpath中添加tset.jar包的引用(在MANIFEST.MF中表现为Bundle-ClassPath: lib/test.jar, 在plugin.xml表现为<runtime>节下的引用

      i.  类文件在lib目录下,如下的设置导出lib目录下所有目录:

            <runtime>

                <library name="lib/">

                 <export name="*"/>

                </library>

            </runtime>

     ii.  test.jar在lib目录下:

            <runtime>

                <library name="lib/test.jar">

                 <export name="*"/>

                </library>

            </runtime>

     iii.  实际上上面的设置可以简化为:

            <runtime>

                <library name="lib/"/>

            </runtime>

        或者

            <runtime>

                <library name="lib/test.jar"/>

            </runtime>

           默认即导出lib目录下的所有包和jar下的所有包

           实际上,执行b)项设置后,会自动执行a)项设置,使开发环境和运行环境同时有效。

    2. 插件B引用插件工程A(非Eclipse插件,而是自己另外一个插件项目中的类)

    a)首先必须将A中的B需要的类暴露(export)出来

    i.如果有MANIFEST.MF文件,则表现为plugin manifest编辑器中runtime节的exported packages,通过这里添加需要export的包。在manifest.mf文件中是Export-Package: com.bbebfe

    ii.如果只有plugin.xml,则表现为plugin manifest编辑器中runtime节的library visibility。在plugin.xml文件中表现为

        <runtime>

           <library>

                  <export name=”com.bbebfe.*”/>

           ...

    b)在B插件工程的plugin manifest编辑器中的dependencies选项卡中添加对A插件的引用(这要求运行对话框中的plugins列表的workspace plugins中必须包含A插件)。

    c)如果B工程是一个RCP工程,则必须在product编辑器的configuration选项卡中包含A插件工程。

    3. 插件B引用Eclipse插件A的类。

    a)Eclipse插件中的类都是Exported,因此这步省略。

    b)在B插件工程的plugin manifest编辑器中的dependencies选项卡中添加对A插件的引用(这要求preferences -> plugin development -> target目标平台必须包含A插件,且运行对话框的plugins列表中的target platform中必须选中A插件)。

    总结:如果B插件引用的A也是一个插件,则A必须出现在B插件的plugin dependencies引用中,而不是其他地方,否则肯定会出现运行时NoClassDefFoundError问题(因此必须在plugin manifest编辑器的dependencies选项卡下进行设置)。而且只需要在这里设置的设置对开发环境和运行环境同时有效)

    注意:还有一种情况就是开发环境没有某个包或者插件,而只在运行环境(target)中存在,此时就必须设置正确的target,然后按照正常程序添加插件引用,但此时已经不能在plugin manifest的dependencies选项卡中设置(因为在开发环境找不到这个plugin),而必须在plugin.xml或MANIFEST.MF文件中手工设置。plugin只要target中存在该插件,则开发和运行也不会有问题。


    ok 下面我说下第四种情况,这个比较特殊,目前百度上也没有搜到类似的解决办法,我是自己瞎试出来的。

    4.我按照上述三种办法进行尝试解决的时候,出现一个问题,首先我的Eclipse插件项目没有MANIFEST.MF文件,而且plugin.xml中已经将所有的包暴漏出来了,但是Eclipse插件运行时候还是报错了,找不到类,那么我就开始思考是不是Eclipse插件运行时环境有缓存没有清掉,我重新clean了一次工程,rebuild了一下class文件,但是依然报错,我就开始翻阅Eclipse运行时的文件夹,一般在:F:wfmSourceWorkSpa ools_v3_ch.metadata.pluginsorg.eclipse.pde.core你的插件项目名 下,我在org.eclipse.osgi找到了一个文件,叫xxx.mf,我打开瞅了一眼,果然没错,我的包少暴漏了一个,于是我干掉了org.eclipse.osgi和org.eclipse.update这2个文件夹,然后重新debug我的工程,代码顺利过去。


    落雨

    2015年2月2日15:37:05

    QQ 394263788

    http://ae6623.cn

  • 相关阅读:
    BitmapFactory.decodeStream(inputStream)返回null的解决方法
    android studio 自用快捷键方案
    jquery源码学习(四)—— jquery.extend()
    css3动画性能优化
    组件化开发之vue
    调用本地摄像头并通过canvas拍照
    傳説中的 jsonp
    jsonp的原理
    正确而又严谨得ajax原生创建方式
    让浏览器阻塞10秒钟的方法
  • 原文地址:https://www.cnblogs.com/ae6623/p/4416250.html
Copyright © 2011-2022 走看看