记一次Java打包之后读取Resources下的文件失效的事情

前言

okey,最近经历的事情有点多,事情有点杂,开始慢慢恢复记忆了。咱的优势就是学的快,劣势就是较高的学习能力,与容量有限的大脑存在主要矛盾。由于硬件本身存在的问题,导致大脑不得不选择LRU与LFU替换策略。因此在重新调入脑存时,中断时间较长。

环境

okey,废话不多说,发车了,事情的起因还是源于一道面试笔试机试题目(这里不能透露太多,但是这道题目很有意思,是一个算法应用,并且这个算法本身也挺有意思的。写完算法之后,还要放在Linux环境当中进行远程调试,说明执行流程)

那么问题就出现在Java打包之后执行代码的时候出现了问题。 在resources下面的话有一个cars.xlsx文件 起初在我们的 idea环境下面测试一点问题没有,直到,我将其打包,并且仔细检查了jar包发现文件资源也打包进去之后,程序还是没有读取到文件的时候,于是发现了一个关于关于使用:

python 复制代码
类名.class.getResource("/cars.xlsx").getPath();

读取resources的坑。打包之后,它是无法读取到文件的。

Why

发现问题,那么就要解决问题,那么问题在哪,凭什么不ok呢。 那么竟然如此,那么我们就要look,look,这个玩意输出的是什么:

python 复制代码
 URL resource = Application.class.getResource("/cars.xlsx");
 String path = resource.getPath();

返回结果是: 显然这个路径是这个: 这个是由IDEA自己生成的一个路径,而在我们打包的时候问什么读取呢? 那么这个时候我们显然需要去看看打包之后的情况: 显然打包到的文件,不在com的同级目录下。

ok,这里我们就明白了一个道理,那就是,之所以找不到,那就是这个打包之后的文件位置放的不一样。那么问题提出来了,那么如何解决这个问题

解决

okey,解决的方式很简单:

python 复制代码
类名.class.getClassLoader().getResourceAsStream("名字");

欸,这样一看,好像区别不大啊,为毛这个可以解决这个问题呢?

对于Class.getResource:

先获取文件的路径path,不以'/'开头时,默认是从此类所在的包下取资源;path以'/'开头时,则是从项目的ClassPath根下获取资源。所以在当前打包之后的 话,我们找不到的,因为这个文件还在外面一层。

对于ClassLoader.getResource:

同样先获取文件的路径,path不以'/'开头时,首先通过双亲委派机制,使用的逐级向上委托的形式加载的,最后发现双亲没有加载到文件,最后通过当前类加载classpath根下资源文件。这样一来当前类没找到,但是老爹,老爷,太爷能找到。

在classLoader里面它的一个过程是这样的:

so,写的时候:

python 复制代码
类名.class.getClassLoader().getResourceAsStream("名字");

总结

陆续开始恢复技术学习,停止考研学习。考研很好,但是不是适合所有人。不过话说回来,太久没老老实实写代码了,好多东西都忘了,今天上午在做远程调试的时候,一直连接不上去,防火墙也放行了,结果搞了半天,发现策略组没放行,无语住了。

相关推荐
掘金者阿豪1 分钟前
千日护航民生支付:一张交通卡背后的国产数据库硬核突围
后端
掘金者阿豪4 分钟前
Copyparty+cpolar,随时随地访问你的私人文件库
后端
苏三说技术13 分钟前
程序员必读的Prompt Engineering指南
后端
Jagger_22 分钟前
一篇文章搞懂DIP依赖倒置原则
后端
beata29 分钟前
Java基础-13: Java反射机制详解:原理、使用与实战示例
java·后端
崔小汤呀33 分钟前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端
颜酱38 分钟前
队列练习系列:从基础到进阶的完整实现
javascript·后端·算法
何中应1 小时前
vi编辑器使用
linux·后端·操作系统
何中应1 小时前
Linux进程无法被kill
linux·后端·操作系统