个人网站做导购可以吗,做短视频的网站收益,如何做网站程序,做网站改字号代码1. Java ClassLoaderJava通过Classloader加载Class#xff0c;Classloader之间相互隔离。隔离真正的意思是#xff1a;不同的Classloader可以加载相同的class定义#xff0c;并且被jvm认定为不同的class。很多人对隔离有误解#xff0c;认为不同的Classloader之间不能相互访…1. Java ClassLoaderJava通过Classloader加载ClassClassloader之间相互隔离。隔离真正的意思是不同的Classloader可以加载相同的class定义并且被jvm认定为不同的class。很多人对隔离有误解认为不同的Classloader之间不能相互访问这其实并不准确。可以这么理解Classloader只是一个普通的Java类加载的class集合是它的一个成员变量。如果一个Classloader中维护了另一个Classloader的引用自然可以通过接口调用查找并使用另一个Classloader加载的类双亲委派使用的正式这种机制。双亲委派这名字乍一听好像是说你有父亲、母亲两个Classloader你可以委派他们两个先去加载class他们处理不了的你再处理。如果真这么理解就全错了。首先他们不是两个可能是n个其次他们不是你的父母他们是整个jvm共享的Classloader第三他们谁的父母都不是因为你和他们没有血缘(别人也没有)你不是双亲Classloader的子类。双亲委派的英文为parent delegation指的是每个Classloader都有一个getParent方法获取上一级的Classloader。查找类时先调用parent Classloader查找如果找不到在用自身的Classloader查找。层级关系如下parent delegation双亲委派实际上只是引用关系上述bootrasp、extension、application Classloader之间关系均属此类。再来看另外一张图自定义Classloaderbootrasp、extension、application Classloader在jvm中只有一个实例多个用户自定义的Classloader共享此实例完成公共部分加载。2. OSGI Classloader在OSGI中每一个Bundle有一个单独的Classloader实例。更具体点BundleWiringImpl中定义了一个BundleClassLoader每当加载一个bundle时框架创建一个BundleClassLoader实例负责该bundle相关class的加载工作。BundleClassLoader的加载顺序如下如class在 java.* package中委托Bootstrap Classloader处理如class定义在 OSGi 框架中启动委托列表(org.osgi.framework.bootdelegation)中则将加载请求委托给Bootstrap Classloader处理如class在 Import-Package 定义的package中则框架找到导出此package的 Bundle 的 Class Loader交其处理 。如class属于在 Require-Bundle 中定义的 Bundle则框架找到导出此package的Bundle的ClassLoader交其处理。Bundle 搜索自己的类资源 ( 包括 Bundle-Classpath 里面定义的类路径和属于 Bundle 的 Fragment 的类资源)若类在 DynamicImport-Package 中定义则开始尝试在运行环境中寻找符合条件的 Bundle 。Bundle之间隔离但如果存在import关系又可以委托给相应export的classloader处理。实现上无非是维护了多个import bundle的Classloader查找时调用其find方法实现。需要注意的是查找时优先查找Import-Package、Require-Bundle中的类随后才是查找Bundle自己的类。这里又引入另外一个疑问Embed-Dependency使用问题。简单来说如果一个Bunlde 需要使用protobuf-java.jar有如下两种使用方式普通的dependency方式使用如下图的Component C的使用方式。Embed-dependency方式使用如下图的ComponentA、ComponentB此时将protobuf-java做为Bundle自身的一部分使用。embed-dependency按类加载的顺序如果先加载Import-Package随后加载自身的Class在外部存在protobuf-java又有内嵌的protobuf-java时如何做到使用自己的而非外部的呢答案是在Embed-dependency中的jar并不会出现在Import-Package中。最后再来讲一下为什么每个bundle需要分配单独的Classloader解决什么问题。在我看来最主要的原因有如下两个定制导出类。非osgi环境下所有package中的java类都将被导出无法限定哪些只能jar内使用哪些是需要export出去的。存在各种误用耦合使用情况。多版本控制。非osgi环境下一个jvm对于一个类只允许存在一个版本。osgi中每个bundle是独立开发演进的可能出现同时存在多个版本。3. 参考资料