百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

java 核心技术-12版 卷Ⅰ- 5.9.3 资源

qihemm 2025-06-13 09:30 8 浏览 0 评论

原文

5.9.3 资源

类通常有一些关联的数据文件,例如:

  • 图像和声音文件。
  • 包含消息字符串和按钮标签的文本文件。

在Java 中,这此关联的文件被称为资源(resource)。

例如,考虑一个显示消息的对话框,如图 5-4 所示。

当然,对于本书的下一版,这个而板中显示的书名和版权年会改变。为了便于追踪这个变化,我们将把这个文本放在一个文件中,而不是作为一个字符串硬编码写到代码中。

但是,应该将类似about.txt 的文件放在哪儿呢?当然,将它与其他程序文件一起放在JAR 文件中会很方便

图 5-4 显示图像和文本资源


Class 类提供了一个很有用的服务可以查找资源文件。下面给出必要的步骤:

  1. 获得拥有资源的类的 Class 对象,例如 ResourceTest.class。
  2. 有些方法(如ImageIcon类的 getImage 方法)接受描述资源位置的 URL。那么,可以调用URL url = cl.getResource("about.gif");
  3. 否则,使用getResourceAsStream 方法得到一个输入流来读取文件中的数据。

这里的重点在于 Java 虚拟机知道如何查找一个类,所以它能搜索相同位置上的关联资源。例如,假设 ResourceTest类在一个 resources 包中。ResourceTest.class 文件就位于 resource目录中,可以把一个图标文件放在同一个目录下。

除了可以将资源文件与类文件放在同一个目录中,还可以提供一个相对或绝对路径,如

data/about.txt

/corejava/title.txt

文件的自动装载是利用资源加载特性完成的。没有标准的方法来解释资源文件的内容。每个程序必须有自己的方法来解释它的资源文件。

另一个经常使用资源的地方是程序的国际化。与语言相关的字符串(如消息和用户界面标签)都存放在资源文件中,每种语言对应一个文件。国际化API(intermationalization API)将在卷2的第7章中讨论。它支持一种标准方法来组织和访问这些本地化文件。

程序清单 5-14 的程序展示了资源加载。(先不用担心读取文本和显示对话框的代码,这

些内容稍后会详细介绍。) 编译、构建一个 JAR 文件执行:

javac resources/ResourceTest.java

jar cvfe ResourceTest.jar resources.ResourceTest resources/*.class resources/*.gif resources/data/*.txt corejava/*.txt

java -jar ResourceTest.jar


将JAR文件移到另外一个不同的目录中,再次运行,以确认程序是从JAR 文件而不是从当前目录读取资源.

程序清单5-14 resources/.java

package resources;

import java.io.*;
import java.net.*;
import java.nio.charset.*;
import javax.swing.*;

/**
 * @version 1.5 2018-03-15
 * @author Cay Horstmann
 */
public class ResourceTest
{
   public static void main(String[] args) throws IOException
   {
      Class cl = ResourceTest.class;
      URL aboutURL = cl.getResource("about.gif");
      var icon = new ImageIcon(aboutURL);

      InputStream stream = cl.getResourceAsStream("data/about.txt");
      var about = new String(stream.readAllBytes(), StandardCharsets.UTF_8);

      InputStream stream2 = cl.getResourceAsStream("/corejava/title.txt");      
      var title = new String(stream2.readAllBytes(), StandardCharsets.UTF_8).strip();

      JOptionPane.showMessageDialog(null, about, title, JOptionPane.INFORMATION_MESSAGE, icon);
   }
}


API java.lang.Class 1.0

  • URL getResource(String name) 1.1
  • InputStream getResourceAsStream(String name) 1.1
  • 找到与类位于同一位置的资源,然后返回一个 URL或者输人流,可以用来加载这个资源。如果没有找到资源,则返回 null,所以不会对 IO 错误抛出异常。


补充说明

本节中的例子需要使用随书附送的资源,资源下载地址如下

本书相关代码下载地址

https://horstmann.com/corejava/

找到 Further Information 节点,

点击 Download Code 后面的 12th edition

会得到一个 corejava.zip 解压到你想要存放的位置

进入 v1ch05,在这里打开CMD 窗口

执行如下命令


javac resources/ResourceTest.java

jar cvfe ResourceTest.jar resources.ResourceTest resources/*.class resources/*.gif resources/data/*.txt corejava/*.txt

java -jar ResourceTest.jar

即可执行相关代码

相关推荐

VLOOKUP的18种高阶用法大公开!99%的人都不知道的神操作!

作为被头条用户催更的Excel课代表,今天带来让HR追着要模板、让老板主动加薪的VLOOKUP终极指南!从基础到高阶一网打尽,文末送36个行业专用模板!一、为什么你的VLOOKUP总报错?血泪大数据...

Vlooup公式,2种模糊查找匹配,1分钟学会

工作中,VLOOKUP公式使用频率是很高的,用来各种查找匹配问题今天我们分享两种模糊查找匹配问题,一种是文本的模糊查找匹配,一种是数字的模糊查找匹配问题1、文本模糊查找匹配使用模拟数据举个例子,原始数...

与vlookup功能相似的函数,照样搞定表格数据查询,简单还实用

在日常表格数据处理工作,说到数据查询,很多小伙伴首先想到的是Vlookup函数,老师的教程中也多次讲到Vlookup函数的用法和实例。其实在Excel中还有其他的数据查询函数公式或技巧,今天我们先来学...

别再折腾VLOOKUP了!DGET逆向查找10秒通关,小白必看

今天要掀翻一个“过气网红”——VLOOKUP!你是不是也经历过这些崩溃瞬间:逆向查找要交换列顺序,复制粘贴到手软!多条件查找要嵌套MATCH,公式长到怀疑人生!别忍了!今天教你用DGET函数一键封...

职场新人必学!VLOOKUP函数10分钟速成指南

正文:"今天来讲解办公人入职期初函数VLOOKUP,这是所有职场人最重要也是最基础的技能。掌握它,90%的数据查找再不用求人!特别献给刚入职场的你——别让Excel成为加班理由。"——...

巧用Vlookup函数揪出“第三者”(vlookup第三个参数是什么)

在一张Excel表格的重复记录中,让你快速列出每种不同物品第2次或第n次出现的记录,你会怎么做?Vlookup函数就有这个本事。举例来说,产品或者物流表格中往往会记录有同一货物的多笔数据(如下图的今日...

分享12个VLOOKUP超经典用法(vlookup通俗易懂)

刚毕业那会,面试的时候经常会被问到会不会用Excel?我就理直气壮地回答:“会啊。”毕竟,简历上可是写着熟练。接着面试官扔出一句“那你会VLOOKUP吗?”我还是会一口咬定:“我会。“其实,我都没用过...

查找匹配别只知道Vlookup,Sumifs也可以!

工作中遇到查找匹配问题的时候,大家第一反应是不是都想到的Vlookup公式呢,有没有小伙伴们给Sumifs一点点机会的呢,有时候Sumifs比Vlookup更好用1、Vlookup公式举个例子,左边是...

Excel函数讲解:VLOOKUP函数,轻松玩转数据查找

常用函数系列教学:VLOOKUP函数讲解(46)。不懂VLOOKUP函数怎么高效查找数据?闲话少叙直接开讲。基本含义:VLOOKUP函数用于在表格按垂直方向(到)上查找返回行数据。如何使用及注意事项?...

CHOOSEROWS+CHOOSECOLS原来是一个超级查找函数组合!

场景一:要在学生名册中,抽查一名学生成绩。公式:=CHOOSEROWS(A1:D5,2)解析:第一参数A1:D5为数据区域,第二参数2表示提取第2行数据。把数据区域改为A2:D5,结合RANDBETW...

数据查询不止有vlookup函数,自定义zlookup函数查询操作更高效

Excel数据查询,相信大家首先会想到vlookup函数。毋庸置疑vlookup函数在Excel数据查询中作用是非常的强大。但是它也有一些不能实现的数据查询。如上图所示,我们需要根据人员的出现次数,提...

「EXCEL进阶」VLOOKUP函数怎么查询一个值返回多个结果

前言:VLOOKUP函数一般一次只能返回一个结果,本例介绍通过辅助列的方法使VLOOKUP函数查询一个值,返回这个值对应的多个结果。使用场景举例:根据表格中同一数值,返回对应值的多个结果。比如这张数据...

WPS查找能手VLOOKUP函数使用方法讲解

各位同学好!今天我们来深度剖析WPS最实用的查找工具——VLOOKUP函数。这个函数能帮你在表格中快速定位并提取所需数据,可以帮你快速核对两批数据差异,还可以合并多个表格的关联信息,甚至可以帮你制作动...

Excel常用10个函数:跨表查找Vlookup,适用于大数据中查找精确值

Hello大家好,我是Office米,今天,我们将和大家一起分享交流,常用的10个函数之一:查找引用函数VLOOKUP。在说VLOOKUP函数之前,我们要先了解,平时Excel日常工作中会遇到哪些问题...

掌握了这个套路,无论用 Excel vlookup 函数查找第几次结果都很轻松

用vlookup查找默认情况下是一对一出结果,如果要一对多查找,就需要用到各种技巧,具体方法我写过非常多了,可以搜索一下历史记录。只要掌握了今天这个套路,无论你想查找第几次重复值,都易如反掌。案例...

取消回复欢迎 发表评论: