小编典典
编译类路径是用于编译Java源文件(使用javac -cp
...或IDE)的类路径。源文件中引用的每个类都必须存在于编译类路径中,否则编译器会抱怨找不到该类。
编译完类后,就可以使用它们运行程序(使用java -cp
...)。显然,源代码直接依赖的库应该在运行时类路径中。但这还不是全部。如果您直接依赖于CoolLibrary.jar,并且此库内部依赖于Guava.jar,那么Guava.jar也必须位于运行时类路径中,尽管在编译时不需要。
Webapp有点特别。Servlet规范指定,用于执行webapp的类路径由部署的webapp的WEB-INF / classes目录以及WEB-INF /
lib中包含的所有jar组成。所有的Web应用程序都可以访问由Tomcat直接提供的本地servlet和JSP
jar。实际上,Tomcat的内部类(例如servlet-
api接口的实现类)也可用于webapp,但是依靠这些类不是一个好主意,因为它将把您的webapp绑定到tomcat。
对于Webapp,谈论运行时类路径有点简化。实际上,每个Webapp的类都是由tomcat的特定类加载器动态加载的。这个webapp类加载器是tomcat类加载器的子类。因此,从理论上讲,您可以将Web应用程序jar直接放置在Tomcat的类路径中,但这意味着所有Web应用程序都将共享这些库,并且在取消部署和重新部署Web应用程序时会遇到问题。例如,每个Web应用程序都有一个特定的类加载器,其目的是能够在同一个JVM中拥有一个依赖于Guava
11.0的应用程序,以及另一个依赖于Guava 12.0的应用程序。
有关tomcat类加载器的更多信息,请阅读文档。
2020-06-16