1、通过类加载器获取路径:

String path = Thread.currentThread().getContextClassLoader().getResource(".").getPath();
           System.out.println(path);
     
           String string = Sample1.class.getClassLoader().getResource(".").getPath();
           System.out.println(string);
     
           String string2 = Sample1.class.getResource(".").getPath();
           System.out.println(string2);

测试结果:

/D:/workspaces/workspace7/demo1/target/classes/
    /D:/workspaces/workspace7/demo1/target/classes/
    /D:/workspaces/workspace7/demo1/target/classes/com/alibaba/

说明:

Classloader读取文件(即方式1和方法2)都是从classpath开始查找文件; 方式3从当前类所在的目录下开始查找文件
不同的工程中,实验如下:

public class Sample2 {
        public static void main(String[] args) {
            Sample1 sample1 = new Sample1();
            sample1.print();
        }
    }

执行结果:

/D:/workspaces/workspace7/demo2/target/classes/
    /D:/workspaces/workspace7/demo2/target/classes/
    /D:/workspaces/workspace7/demo1/target/classes/com/alibaba/

说明:Classloader获取的内容始终从调用方出发,即当前调用的加载器; 而一般类的资源获取是从类自身的位置触发

当获取当前类路径下的文件使用:
InputStream f=TestDemo.class.getResourceAsStream("book.xml");//book.xml与TestDemo.class同意路径下
而加载classpath下的文件book.xml使用以下方式
InputStream f=TestDemo.class.getClassLoader().getResourceAsStream("book.xml");//book.xml与TestDemo.class同意路径下

注意:通过以下获取资源获取的都是相对路径下文件
InputStream in = new FileInputStream("abc.properties"); // 相对路径,项目下的路径 与ClassLoader加载有什么区别吗
OutputStream out = new FileOutputStream("abc.properties");

通过加载器进行加载类路径创建对象
        String loaderClassName="com.mysoft.test.classloader.ClassLoaderTest";
        Class<?> loaderClass = null;
        loaderClass = ClassLoaderTest.class.getClassLoader().loadClass(loaderClassName);
        ClassLoaderTest s=(ClassLoaderTest)loaderClass.newInstance();
        System.out.println(s.getName());
        
        Class<?> loaderClass2 = null;
        ClassLoader cl=Thread.currentThread().getContextClassLoader();//获取当前线程的加载器,安全起见采用该方式
        loaderClass2=cl.loadClass(loaderClassName);
        ClassLoaderTest s2=(ClassLoaderTest)loaderClass2.newInstance();
        System.out.println(s2.getName());

ClassLoader类加载解惑的更多相关文章

  1. ClassLoader类加载机制&&JVM内存管理

    一.ClassLoader类加载机制 在java中类加载是遵循委派双亲加载的:通过调用loadClass方法逐级往上传递委派加载请求,当找不到父ClassLoader时调用其findClass方法尝试 ...

  2. Java运行时环境---ClassLoader类加载机制

    背景:听说ClassLoader类加载机制是进入BAT的必经之路. ClassLoader总述: 普通的Java开发其实用到ClassLoader的地方并不多,但是理解透彻ClassLoader类的加 ...

  3. ClassLoader类加载器 & Java类加载机制 & 破坏双亲委托机制

    ClassLoader类加载器 Java 中的类加载器大致可以分成两类: 一类是系统提供的: 引导类加载器(Bootstrap classloader):它用来加载 Java 的核心库(如rt.jar ...

  4. 进阶Java编程(11)ClassLoader类加载器【待完成】

    1,ClassLoader类加载器简介 在Java里面提供一个系统的环境变量:ClassPath,这个属性的作用主要是在JVM进程启动的时候进行类加载路径的定义,在JVM里面可以根据类加载器而后进行指 ...

  5. 万万没想到,面试中,连 ClassLoader类加载器 也能问出这么多问题…..

    1.类加载过程 类加载时机 「加载」 将类的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在内存上创建一个java.lang.Class对象用来封装类在方法区内的数据 ...

  6. Java安全之 ClassLoader类加载器

    Java安全之 ClassLoader类加载器 0x00 前言 前面这里抛出一个问题,Java到底是什么类型的编程语言?是编译型?还是解释型?在这个问题是其实一直都都有疑惑,如果说是解释型语言的话,那 ...

  7. ClassLoader类加载机制

    一.类加载器 类加载器(ClassLoader),顾名思义,即加载类的东西.在我们使用一个类之前,JVM需要先将该类的字节码文件(.class文件)从磁盘.网络或其他来源加载到内存中,并对字节码进行解 ...

  8. ClassLoader类加载器

    总的来说,当动态加载一个资源时,至少有三种类加载器可供选择: 系统类加载器(也被称为应用类加载器)(system classloader) 当前类加载器(current classloader) 当前 ...

  9. Java URLClassLoader 和 ClassLoader类加载器

    开始:看名字都带有ClassLoader,叫做类加载器,事实上是可以理解为动态的加载类,不过,也不是只能加载类,也可以加载其他形式的文件,比如说.properties属性文件. 区别:其实在两个类加载 ...

随机推荐

  1. 2017中国数据库技术大会(DTCC)又要来啦!期待~~

    2017第八届中国数据库技术大会(DTCC2017)将于2017年5月11-13日如约而至.2017中国数据库技术大会(DTCC)以"数据驱动•价值发现"为主题,汇集来自互联网.电 ...

  2. [M]带属性块参照的转换

    有一张表格,表格的每一行都由带有属性的块参照组成,如图: 魔法表格不能直接识别有块参照组成的表格,需要使用 EXPLODE 命令将块参照分解,但多分解带有属性的块只能得到属性的定义 这是就需要使用 B ...

  3. nginx(1)

    下一篇:nginx(2) 一.engin X 市场的服务器非常的多,这里简单介绍几种常用的. Apache:源代码开放,跨平台,可移植,且支持的模块非常丰富,虽然在速度性能上不如其他轻量级的web服务 ...

  4. Struts2中实现文件上传的功能

    1.首先得配置一下Struts得配置文件struts-xml: <?xml version="1.0" encoding="UTF-8" ?> &l ...

  5. Java之JSP基础语法

    1.JSP页面元素简介及page指令     2.JSP注释,3种不同注释 <!--  我是HTML注释,在客户端可见 --> <%--我是JSP注释,在客户端不可见 --%> ...

  6. Mac下如何使用Vim

    帖子是转载的,原帖地址 Mac OX其实已经默认装好了vim了.不需要再安装Macvim https://ruby-china.org/topics/4905 Mac开发利器之程序员编辑器MacVim ...

  7. ring3 hook ZwWriteVirtualMemory

    typedef LONG NTSTATUS;typedef NTSTATUS (NTAPI *PNtZwWriteVirtualMemory) ( IN HANDLE hProcess, IN PVO ...

  8. Python基础(十一)-面向对象

    三种编程范式: 1.函数式编程:函数指数学意义上的函数 由于命令式编程语言也可以通过类似函数指针的方式来实现高阶函数,函数式的最主要的好处主要是不可变性带来的.没有可变的状态,函数就是引用透明(Ref ...

  9. vsftp建立虚拟用户不同目录分配不同权限操作步骤详解

    vsftpd服务器同时支持匿名用户.本地用户和虚拟用户三类用户账号,使用虚拟用户账号可以提供集中管理的FTP根目录,方便了管理员的管理,同时将用于FTP登录的用户名.密码与系统用户账号区别开,进一步增 ...

  10. C++设计模式-singleton单例模式_new

      class nocopyable { protected: nocopyable(){}; virtual ~nocopyable(){}; nocopyable(const nocopyable ...