在看下面的实现之前,可以先了解下面的几篇文章内容:
1 https://blog.csdn.net/u013412772/article/details/80837735
2 https://blog.csdn.net/u013412772/article/details/80842636
3 https://blog.csdn.net/u013412772/article/details/80851700
4 https://blog.csdn.net/u013412772/article/details/80865875
5 https://blog.csdn.net/u013412772/article/details/80906997
模块隔离功能:每个模块使用一个类加载器进行加载,每个模块独立作为一个Jar包对外提供功能.我们把每个模块的Jar里面的类加载到一个内存map,然后再创建一个自定义类加载器,重写loadClass方法,当加载类时候优先在内存map里面查找,如果存在则直接返回,否则调用默认加载方法.工程结构图如下:
将demo_classloader工程使用maven的命令clean package
命令打包成jar包(demo_classloader的pom.xml设置打包形式也是jar),如下所示:
在target目录下找到打成jar的文件:
其中datamanager工程里面的classloader包里面的ModuleManager是核心类,实现了从不同模块加载jar里面的类到内存map的功能,核心代码如下:
import java.io.File;
import java.net.URL;
import java.net.URLClassLoader;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.List;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.jar.JarEntry;
import java.util.jar.JarFile;
import com.alibaba.druid.util.StringUtils;
public class ModuleManager {
/**
* 用来并发加载多个模块jar
*/
private ExecutorService e