Classloader是从classpath中读取资源的一个类,一般我们用classloader来加载class,实际上,但凡是处在classpath中的文件,我们称之为资源,都可以用classloader来读取。
在java中的API里,有两种方式来使用classpath读取资源。
[quote]System.out.println(Bootstrap.class.getResource(""));
System.out.println(Bootstrap.class.getResource("/"));
System.out.println(Bootstrap.class.getClassLoader().getResource(""));
System.out.println(Bootstrap.class.getClassLoader().getResource("/"));
System.out.println(Bootstrap.class.getResource("name.properties"));
System.out.println(Bootstrap.class.getResource("/name.properties"));
System.out.println(Bootstrap.class.getClassLoader().getResource("name.properties"));[/quote]
class里有一个getResource方法,classloader类里也有getResource方法,这两种API都可以从classpath中读取资源,但是也有一些区别。
class的getResource方法实际上也是用classloader来读取资源,但是起始路径不一样
[quote]System.out.println(Bootstrap.class.getResource(""));[/quote]
这个API的起始路径是当前类的路径,如果要正确的读到资源,目标资源必须和当前class在同一级,或子目录里,可以用相对路径读取到。
[quote]System.out.println(Bootstrap.class.getResource("/"));
System.out.println(Bootstrap.class.getClassLoader().getResource(""));[/quote]
加上/的读取方式,和调用classloader读取是同一个效果,这个读取代表的是某个classpath下的根路径。
[quote]System.out.println(Bootstrap.class.getClassLoader().getResource("/"));[/quote]
[color=red][b]这是一种错误的读取方式,使用classloader的时候,不可以指定/来读取。 [/b][/color]
例:
[quote]System.out.println(Bootstrap.class.getResource("name.properties"));
System.out.println(Bootstrap.class.getResource("/name.properties"));
System.out.println(Bootstrap.class.getClassLoader().getResource("name.properties")[/quote]
第一种读取,代表读取当前类同一级的文件name.properties
第二种和第三种读取等效,都是读取任意classpath根路径下的name.properties文件
MARK
在启动服务的时候,所有的依赖项都是以目录的形式存在在classpath下,这样classloader才能一个一个去加载,而getResource的API里的路径,也都是相对于每一个依赖的目录的路径。
参考:http://www.tuicool.com/articles/f6bYZj
http://lionbule.iteye.com/blog/1285323
在java中的API里,有两种方式来使用classpath读取资源。
[quote]System.out.println(Bootstrap.class.getResource(""));
System.out.println(Bootstrap.class.getResource("/"));
System.out.println(Bootstrap.class.getClassLoader().getResource(""));
System.out.println(Bootstrap.class.getClassLoader().getResource("/"));
System.out.println(Bootstrap.class.getResource("name.properties"));
System.out.println(Bootstrap.class.getResource("/name.properties"));
System.out.println(Bootstrap.class.getClassLoader().getResource("name.properties"));[/quote]
class里有一个getResource方法,classloader类里也有getResource方法,这两种API都可以从classpath中读取资源,但是也有一些区别。
class的getResource方法实际上也是用classloader来读取资源,但是起始路径不一样
[quote]System.out.println(Bootstrap.class.getResource(""));[/quote]
这个API的起始路径是当前类的路径,如果要正确的读到资源,目标资源必须和当前class在同一级,或子目录里,可以用相对路径读取到。
[quote]System.out.println(Bootstrap.class.getResource("/"));
System.out.println(Bootstrap.class.getClassLoader().getResource(""));[/quote]
加上/的读取方式,和调用classloader读取是同一个效果,这个读取代表的是某个classpath下的根路径。
[quote]System.out.println(Bootstrap.class.getClassLoader().getResource("/"));[/quote]
[color=red][b]这是一种错误的读取方式,使用classloader的时候,不可以指定/来读取。 [/b][/color]
例:
[quote]System.out.println(Bootstrap.class.getResource("name.properties"));
System.out.println(Bootstrap.class.getResource("/name.properties"));
System.out.println(Bootstrap.class.getClassLoader().getResource("name.properties")[/quote]
第一种读取,代表读取当前类同一级的文件name.properties
第二种和第三种读取等效,都是读取任意classpath根路径下的name.properties文件
MARK
在启动服务的时候,所有的依赖项都是以目录的形式存在在classpath下,这样classloader才能一个一个去加载,而getResource的API里的路径,也都是相对于每一个依赖的目录的路径。
参考:http://www.tuicool.com/articles/f6bYZj
http://lionbule.iteye.com/blog/1285323