Difference between getClass().getClassLoader().getResource() and getClass.getResource()?
The second one calls the first one. The difference is described in the javadoc.
The first one takes paths that don't start with a /
, and always starts at the root of the classpath.
The second one takes path that can start with a /
. If it does, it starts at the root of the classpath. If not, it starts at the package of the class on which the method is called.
So getClass().getClassLoader().getResource("foo/bar.txt")
is equivalent to getClass().getResource("/foo/bar.txt")
.
And, assuming getClass() returns a class that is in the package foo
, getClass().getResource("bar.txt")
is equivalent to getClass().getClassLoader().getResource("foo/bar.txt")
which one should I use in what circumstances?
Neither. You should call Thread.currentThread().getContextClassLoader()
.
This has the benefit of not needing to be changed depending on whether you're calling from a static or instance method.
And more important, it will properly handle classloader delegation inside a container. If you don't use it, you might find that an "application" resource isn't found because the class that's loading it was loaded by a classloader higher up the delegation hierarchy.
Basically, Class.getResource()
allows you to specify a path relative to the package of the class, whereas ClassLoader.getResource()
is always an "absolute" path.
So:
foo.bar.Baz.class.getResource("data.txt")
is equivalent to:
some.Other.class.getResource("/foo/bar/data.txt")
and they're both equivalent to:
some.Other.class.getClassLoader().getResource("foo/bar/data.txt")
(Assuming some.Other
and foo.bar.Baz
are loaded by the same classloader, of course.)