再次理解Eclipse的类加载机制

今天在写RCP的基础运行插件的时候,发现一个非常有意思的问题:
    我有两个插件A和B,A是RCP运行主插件,B是普通插件,A依赖于B存在并运行。当我把B打成JAR包,放到A下,做本地依赖的时候,那么Log4j的配置文件加载无误,但是这样是违反了Eclipse插件开发原则(Eclipse最小运行单位是插件)的;我把A和B通过feature进行关联,然后在A中依赖B插件,通过product文件启动A插件的时候,发现B插件无法加载Log4j的配置文件... ...
    很郁闷的问题哦~为什么?
    因为我一直在使用原来java的类加载机制思考问题,一个类加载机,将加载所有的Class~在Eclipse下则不是这样的,每一个类加载机只负责一个插件的内容加载~多个类加载机之间是没有关系的~
    因此,每一个插件在类加载时都是独立的个体~所以每一个插件下面都需要自行增加一个Log4j配置文件,大家都独立维护自己的Log4j配置文件~唉,有一个配置文件泛滥的年代啊~


ps:

深入剖析 Eclipse 类装入器

你可能感兴趣的:(eclipse,log4j)