首页 > 代码库 > 有关getClassLoader().getResourceAsStream(fileName)、class.getResourceAsStream(fileName)和().getContextClassLoader().getResourceAsStream(fileName)的区别

有关getClassLoader().getResourceAsStream(fileName)、class.getResourceAsStream(fileName)和().getContextClassLoader().getResourceAsStream(fileName)的区别

    一:前言

    在自己获取属性时,碰见了XX.class.getResourceAsStream(fileName),自己对这个其实不是很理解,上网查了下资料,又看到了上述的几个,所以就研究了下。

 

二:内容

  先说说着几个区别吧

  getClassLoader().getResourceAsStream("a.txt"):此方法的路径不管是绝对路径还是想对路径,都是从path下找得,即使"./a.txt"的形式去寻找,在此处我们要注意空指向异常的情况(可以看看这里写的http://cache.baiducontent.com/cm=9d78d513d99c12eb0fb1837e7c4380200e55f0326284915468d5e316ce370d160771e2cb30536713a0b66b6671f30e02b4e47132690c7af1dd8a9f4baea68f7871d57223706bdd124d9b58e5dc46529e778d1bb3f25cf0ba8768d5f18cc4de20089c44040c84f3895803&p=9274c54ad5c246e74bbe9b7c4605bb&newp=867cc54ad5c246bc4bbe9b7c4f0a9f231610db2151d6d11f6cc7&user=baidu&fm=sc&query=maven+getClassLoader%CE%AAnull&qid=bf473e2d0001b6a7&p1=3)。其中写到了Bootstrap ClassLoader (启动类加载器或者叫引导类加载器)加载jdk核心的APIs,这些APIs一般位于jdk_home/lib下;它是一个本地接口,所以不能从java代码中得到它的信息。例如, log(java.lang.String.class.getClassLoader())得到的是null(引用自http://blog.csdn.net/benjieming_wang/article/details/5623492)。classLoader是一种类加载器.

现在我就来附上代码说明吧:

package org.wh.properties;import java.io.IOException;import java.io.InputStream;import java.util.Iterator;import java.util.Properties;import java.util.Set;public class PropertiesDemo01 {    Properties prop;    public void setProp(Properties prop) {        this.prop = prop;    }    public static void main(String args[]){        loadConfig();    }    public static  Properties loadConfig(){        Properties prop = new Properties();        //Class的getResource()方法是从当前.class文件路径查找资源,而ClassLoader则是从jar包中查找        //InputStream input = Properties.class.getResourceAsStream("/jdbcUtils.properties");        InputStream input1 = PropertiesDemo01.class.getClassLoader().getResourceAsStream("jdbcUtils.properties");        System.out.println("jdk的类加载器"+Properties.class.getClassLoader());//结果:jdk的类加载器:null        System.out.println("demo:"+PropertiesDemo01.class.getClassLoader());//结果:demo:sun.misc.Launcher$AppClassLoader@addbf1        try {            prop.load(input1);            @SuppressWarnings("rawtypes")            Set keyValue=prop.keySet();            for(Iterator a=keyValue.iterator();a.hasNext();){                String key=(String) a.next();                String value=prop.getProperty(key);                System.out.println("-key的值--"+key+"value--的值-"+value);            }        } catch (IOException e) {            e.printStackTrace();        }        return prop;    }}
结论:如果在这里用jdk的内部类就会报空指向异常,我们可以看到Properties.class.getClassLoader()得到的结果是null;

class.getResourceAsStream(fileName):fileName中加了“/”则代表了绝对路径,否则就是相对路径。代码可见上述
再说说Thread.currentThread().getContextClassLoader():这个是当前线程的类加载器,

package org.wh.properties;public class Test {    public static void main(String[] args) {                System.out.println(Thread.currentThread().getContextClassLoader());//当前线程的类加载器        System.out.println(Test.class.getClassLoader());//当前类的类加载器        System.out.println(ClassLoader.getSystemClassLoader());//系统初始的类加载器    }}

参考资料可以看看这里:http://stackoverflow.com/questions/676250/different-ways-of-loading-a-file-as-an-inputstream
  


有关getClassLoader().getResourceAsStream(fileName)、class.getResourceAsStream(fileName)和().getContextClassLoader().getResourceAsStream(fileName)的区别