Java项目中获取路径的绝对路径问题和相对路径问题
作者:华为云开发者社区 发布时间:2023-07-09 13:25:01
前言:
在纯 Java 代码里 我们一般都会用class.getResource(String name) 或
者 class.getClassLoader().getResource(String name)
两种方法获取文件的地址 (当然不止这两种方法)。今天就说说这两种方法的异同。这里说的纯 Java 代码不是 Java web 项目。
1.目录结构
2.class.getResource(String name)
输入:可以接受相对路径(相对于该 class 类)或者绝对路径(根目录符号为 / 代表项目的根目录 不代表硬盘的根目录)
返回:URL 对象 该对象表示指向 name 的资源
// 获取相对路径 此时获取的是该class文件的同级目录
System.out.println("相对路径:同级目录下的配置文件>"+Main.class.getResource("demo.properties"));
// 获取的绝对路径 相对于跟目录来说的
System.out.println("绝对路径:同级目录下的配置文件>"+Main.class.getResource("/com/xing/demo/demo.properties"));
System.out.println("相对路径:上一级目录下的配置文件>"+Main.class.getResource("../xing.properties"));
System.out.println("绝对路径:根目录下的配置文件>"+Main.class.getResource("/src.properties"));
// 当传入的是绝对路径(带有‘/')的时候,getresource()方法会从项目的根目录开始解析路径地址
输出:
相对路径:同级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
绝对路径:同级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
相对路径:上一级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/xing.properties
绝对路径:根目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
3.class.getClassLoader().getResource(String name)
输入:只能接受相对路径 但此相对路径是相对于根目录来说的
返回:URL 对象
// src 在根目录下 这里的同级也就是根目录了
System.out.println("相对路径:同级目录下的配置文件>"+Main.class.getClassLoader().getResource("src.properties"));
System.out.println("相对路径:相对根目录的下一级目录下的配置文件>"+Main.class.getClassLoader().getResource("com/com.properties"));
System.out.println("相对路径:相对根目录的下下一级目录下的配置文件>"+Main.class.getClassLoader().getResource("com/xing/xing.properties"));
输出:
相对路径:同级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
相对路径:相对根目录的下一级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/com.properties
相对路径:相对根目录的下下一级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/xing.properties
注意:
/**
* 下面两种有相同的作用
*/
System.out.println("==相对路径:同级目录下的配置文件>"+Main.class.getResource("demo.properties"));
System.out.println("==相对路径:相对根目录的下下一级目录下的配置文件>"+Main.class.getClassLoader().getResource("com/xing/demo/demo.properties"));
输出:
==相对路径:同级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
==相对路径:相对根目录的下下一级目录下的配置文件>file:/E:/ideawork/pathdemo/out/production/pathdemo/com/xing/demo/demo.properties
3.1区别
两者的区别:
其实我们看源码就知道class.getResource
其实就是用的 class.getClassLoader().getResource(String name)
。
只不过是class.getResource
会通过 resolveName
这个方法把传入的路径都转换为符合 class.getClassLoader().getResource()
的路径 然后让 getClassLoader
处理。
3.2ClassLoader
class.getClassLoader().getResource(String name)
使用的是 ClassLoader
,而 ClassLoader
的获取是有很多方法的。
获取 classLoader 的方法:
Thread.currentThread().getContextClassLoader()
ClassLoader.getSystemClassLoader().
class.getClassLoader()
System.out.println(Thread.currentThread().getContextClassLoader().getResource("src.properties"));
System.out.println(ClassLoader.getSystemClassLoader().getResource("src.properties"));
输出:
file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
file:/E:/ideawork/pathdemo/out/production/pathdemo/src.properties
扩展一下: 获取项目的硬盘目录 直到项目名级别的目录
// 输出:E:\sparkwork\pathdemo
System.out.println(System.getProperty("user.dir"));
3.3关于 URL 的一些知识
URL fileURL = Main.class.getResource("/src.properties");
// 输出:file:/E:/sparkwork/pathdemo/out/production/pathdemo/src.properties
System.out.println(fileURL.toURI());
// 输出:/E:/sparkwork/pathdemo/out/production/pathdemo/src.properties
System.out.println(fileURL.getPath());
// 这两种方法都是可以的
File file = new File(fileURL.toURI());
Filw file2 = new File(fileURL.getPath())
来源:https://blog.51cto.com/u_15214399/5010698


猜你喜欢
- using System; using System.Drawing; using System.Windows.Forms; using
- 一、什么是简单工厂模式简单工厂模式又称为静态工厂模式,实质是由一个工厂类根据传入的参数,动态决定应该创建哪一个产品类(这些产品类继承自一个父
- 在之前的博客使用SpringMVC创建Web工程并使用SpringSecurity进行权限控制的详细配置方法 中,我们描述了如何配置一个基于
- Activiti 介绍Activiti是一个开源的工作流引擎,它实现了BPMN 2.0规范,可以发布设计好的流程定义,并通过api进行流程调
- 这篇文章主要介绍了通过实例解析JMM和Volatile底层原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
- 在上篇文章给大家介绍了使用XSD校验Mybatis的SqlMapper配置文件的方法(1),需要的朋友可以参考下。编写好XSD文件,然后来看
- SpringBoot遇到的坑@Qualifier报红今天写项目的时候@Qualifier一直报红,排查半天后面才知道原来是idea生成项目的
- 前言异步调用几乎是处理高并发,解决性能问题常用的手段,如何开启异步调用?SpringBoot中提供了非常简单的方式,就是一个注解@Async
- 前言我们在很多博客中都有发现,Seata AT模式里面的全局锁其实是行锁,这也是Seata AT模式和XA模式在锁粒度上的最大区别。我们可以
- Redis模糊匹配批量删除操作,使用RedisTemplate操作: public void deleteByPrex(String pre
- SpringBoot多线程进行异步请求的处理近期在协会博客园中,有人发布了博客,系统进行查重的时候由于机器最低配置进行大量计算时需要十秒左右
- 一、 Sharding-jdbc简介“Sharding-jdbc是开源的数据库操作中间件;定位为轻量级Java框架,在Java的JDBC层提
- 有时,通过Runtime.getRuntime().exec()执行命令的有效负载有时会失败。使用Web Shell,反序列化利用或通过其他
- 项目中需要判断传入的日期是否在未来的一年以内,百度了一下网上没有找到好的方式,写了,方便自己和他人:int datecompareAfter
- 安装Free Mybatis plugin即可安装MyBatisCodeHelper插件(推荐)补充:IDEA插件(mybatis框架下ma
- 导入maven依赖<!-- https://mvnrepository.com/artifact/com.fasterxml.jack
- 我们知道 Spring Boot 已经提供了一套默认的异常处理机制,但是 Spring Boot 提供的默认异常处理机制却并不一定适合我们实
- 前言之前看到某公司的官网的文章的浏览量刷新一次网页就会增加一次,给人的感觉不太好,一个公司的官网给人如此直白的漏洞,我批量发起请求的时候发现
- 下面的方法返回false表示网络不通// 检测网络 public static boolean checkNetworkAvailable(
- 前言:线程安全是并发编程中的重要关注点,造成线程安全问题的主要原因有两点,一是存在共享数据(也称临界资源),二是存在多条线程共同操作共享数据