ClassLoader确定资源的位置(取自ClassLoader JavaDoc):
ClassLoader类使用委托模型搜索类和资源。 每个ClassLoader实例都有一个关联的父类加载器。 当请求查找类或资源时,ClassLoader实例会将对类或资源的搜索委托给其父类加载器,然后再尝试查找类或资源本身。 虚拟机的内置类加载器(称为“引导类加载器”)本身没有父级,但可以用作ClassLoader实例的父级。
因此,无论在代码中调用Class#getResource还是Class#getResourceAsStream的任何地方,都会发生这种情况(取自Class.java)
public java.net.URL getResource(String name) {
name = resolveName(name);
ClassLoader cl = getClassLoader0();
if (cl==null) {
// A system class.
return ClassLoader.getSystemResource(name);
}
return cl.getResource(name);
}
class loader.Java:
public URL getResource(String name) {
URL url;
if (parent != null) {
url = parent.getResource(name);
} else {
url = getBootstrapResource(name);
}
if (url == null) {
url = findResource(name);
}
return url;
}
实际上,ClassLoader#findResource会被ClassLoader实现覆盖。 这意味着在应用程序服务器,TomCat上的行为是不同的,或者如果您从jar文件运行,则取决于您当前所在环境的ClassLoader实现。
这是一个示例,您可以使用它来跟踪特定情况下的实际情况。