关于spring和web项目开发中的classpath以及依赖的jar包中的classpath的路径,spring MVC装载过程中classpath的扫描

关于spring和web项目开发中的classpath以及依赖的jar包中的classpath的路径,spring MVC装载过程中classpath的扫描。

src不是classpath, WEB-INF/classes,lib才是classpath。WEB-INF/ 是资源目录, 客户端不能直接访问,
这话是没错,不过现在的IDE编译器在编译时会把src下的文件(是文件,不是.java)移到WEB-INF/classes下。不过值得注意的 是,spring配置文件里这个locations是uri表示,也就是说你写的jdbc.properties是当前相对路径,要访问 classpath记得要这样写:classpath:jdbc.properties

首先 classpath是指 WEB-INF文件夹下的classes目录
解释classes含义:
1.存放各种资源配置文件 eg.init.properties log4j.properties struts.xml
2.存放模板文件 eg.actionerror.ftl
3.存放class文件对应项目开发时的src目录编译文件(Class文件夹内放置的是.class编译文件)
总结:这是一个定位资源的入口

对于第二个问题
这个涉及的是lib和classes下文件访问优先级的问题: lib>classes
对于性能的影响应该不在这个范畴

classpath 和 classpath* 区别:

classpath:只会到你的class路径中查找找文件;
classpath*:不仅包含class路径,还包括jar文件中(class路径)进行查找.


JavaEE中classpath与系统环境变量中的classpath不一样,WEB应用中的classpath专指项目WEB-INF/classes和WEB-INF/lib,web容器在启动时会对WEB-INF/classes和WEB-INF/lib目录下的class文件、配置文件以及jar文件进行加载,当然,配置文件的加载是根据web.xml中的配置(显示配置了文件路径或者配置了其它类而在类内部进行加载配置文件)来的,web容器并不会自动加载WEB-INF/classes下的配置文件。

类装载工作是由ClassLoader及其子类负责。JVM在运行时会产生3个ClassLoader:根装载器, ExtClassLoader(扩展类加载器)和AppClassLoader(应用类装载器)。其中,根装载器不是ClassLoader的子类,它使用C++语言编写,因而在java中看不到它,根装载器负责装载JRE的核心类库。ExtClassLoader和AppClassLoader都是ClassLoader的子类,其中ExtClassLoader负责装载JRE扩展目录ext中的JAR类包;AppClassLoader负责装载Classpath路径下的类包。

AppClassLoader的父装载器是ExtClassLoader, ExtClassLoader的父装载器是根装载器。

类的加载使用双亲委派模式。这样可以确保与jre库文件全限定名一致的类只能由根加载器加载,以免用户编写的与核心类库同名的类加载到jvm中。

所以WEB-INF/classes和WEB-INF/lib目录下的class文件,以及jar文件是由APPClassLoader加载的。运行时需要的类是由根装载器加载的,不会出现在Spring项目的classpath下。

你可能感兴趣的:(架构师成长之路,前后端)