• java中获取类资源的不同姿势


    介绍两种获取资源的方式:

    一、通过ClassLoader获取:
       loader.getResourceAsStream("a/b/temp.txt");--获取src下/a/b包下的temp.txt资源
    二、通过Class获取:
       加"/":
          与ClassLoader一样。class.getResourceAsStream("/a/b/temp.txt")
       不加"/":
          class.getResourceAsStream("temp.txt")。表示获取当前类路径下的资源。

    举个栗子:

    【项目路径如下】

     【classes路径如下

    测试代码

    package com.io.test;
    
    import java.io.InputStream;
    
    public class TestIo {
        public static void main(String[] args) {
            //一、通过ClassLoader方式
            ClassLoader loader = TestIo.class.getClassLoader();//直接从跟路径搜索
            InputStream a1 = loader.getResourceAsStream("a.txt");
            InputStream b1 = loader.getResourceAsStream("test/file/b.txt");
            InputStream c1 = loader.getResourceAsStream("com/io/test/c.txt");
            System.out.println("a1=>"+a1);
            System.out.println("b1=>"+b1);
            System.out.println("c1=>"+c1);
            
            //二、通过Class方式
            Class<TestIo> clazz = TestIo.class;
            InputStream a2 = clazz.getResourceAsStream("/a.txt");//斜杠表示直接从根路径开始搜索
            InputStream a3 = clazz.getResourceAsStream("../../../a.txt");//通过相对路径
            InputStream c2 = clazz.getResourceAsStream("c.txt");//当前类路劲,相对路径
            InputStream c3 = clazz.getResourceAsStream("/com/io/test/c.txt");//从跟路径开始搜索
            System.out.println("a2=>"+a2);
            System.out.println("a3=>"+a3);
            System.out.println("c2=>"+c2);
            System.out.println("c3=>"+c3);
        }
    }
    a1=>java.io.BufferedInputStream@15db9742
    b1=>java.io.BufferedInputStream@6d06d69c
    c1=>java.io.BufferedInputStream@7852e922
    a2=>java.io.BufferedInputStream@4e25154f
    a3=>java.io.BufferedInputStream@70dea4e
    c2=>java.io.BufferedInputStream@5c647e05
    c3=>java.io.BufferedInputStream@33909752
    "我们所要追求的,永远不是绝对的正确,而是比过去的自己更好"
  • 相关阅读:
    CSS布局设计
    Gulp自动化构建工具的简单使用
    雅虎前端优化的35条军规
    CSS预编译器less简单用法
    java 数据相除
    idea 配置文件中文显示问题
    postgresql 表触发器
    postgresql 自定义函数
    postgresql 自定义聚合函数
    CentOS 6.5 yum安装mysql5.6或其他版本【默认yum只能安装mysql 5.1】 by jason
  • 原文地址:https://www.cnblogs.com/zomicc/p/12259483.html
Copyright © 2020-2023  润新知