获取jar包路径和所在目录的几种方法 java 路径

今天找了半天的毛病 关于java的一个写入记事本的小程序 封装成jar包后 因为我的机器上有运行环境 所以双击 就能在jar包的所在位置执行 并且生成了一个记事本 但是在控制台里用java -jar 执行的时候 就没有生成记事本 其实最后发现也不是没有生成 是生成在了 控制台的当前目录下 比如在d盘执行 就生成在d盘了 而我的jar包 在桌面呢 一开始以为是打的命令有错误 然后发现就是控制台路径的问题 只要把控制台的路径放大jar包的位置 就可以在那生成 记事本文件 然后 我开始改代码 什么相对路径 绝对路径的 大改了一通 发现网上好多说的都不对 因为在封装成jar包之后 就和在开发环境里执行的效果是不一致的 甚至是执行不了 好了 牢骚 就发到这吧 以上是我的经历 下面开始转载 这篇文章转自:http://www.cherrot.com/2012/02/howto-get-directory-of-jar-archive

之前转过一篇文章,详细介绍了如何读取保存在jar包内的资源文件。今天又遇到个问题,如何定位jar包所在位置呢?比如要输出错误日志到jar包的同级目录时,我们就需要知道jar包存放的目录。众所周知,未打包的.class文件获取当前目录很容易,但是打包成.jar文件就迥然不同了
搜来搜去,找到两个办法:
方法一:使用类路径
String path = getClass().getProtectionDomain().getCodeSource().getLocation().getPath()
这种方法可以得到当前程序jar文件的绝对路径(字符串值)。如果以被打成jar包,调用getFile()或调用getPath()得到的结果是相同的,均为 the/path/to/abc.jar 的形式。然而如果是class文件的话,两个方法调用返回的是不同的结果,这里不多做解释。
使用该方法得到的字符串是定位到jar文件的,如果想只得到jar文件所在目录,那么需要对该字符串再做处理,或者在getLocation()方法返回的URL上作处理。另外注意,如果路径包含Unicode字符(汉字),那么还需要使用 java.net.URLDecoder.decode(path, “UTF-8″) 方法进行转码,其中path是需要转码的字符串路径。
方法二:使用JVM属性
String path = System.getProperty("java.class.path")
这里使用了java运行时的系统属性来得到jar文件的位置,结果同1方法大致相同,且不需要做转码处理。 更多系统属性参见Oracle的说明。在使用class测试时,该方法得到的路径为 “类库路径:当前class路径”(Windows系统应该显示”类库路径;当前class路径”),然而运行jar包时只会得到我期望的jar包路径,这一点有点不解。
从jar包路径的到jar包的目录,我的方法是:

int firstIndex = path.lastIndexOf(System.getProperty("path.separator"))+1
int lastIndex = path.lastIndexOf(File.separator) +1;
path = path.substring(firstIndex, lastIndex);
当然,如果是采用方法一,就不需要计算firstIndex了。
另外为了扫盲,注明下面这写忽悠人的错误做法
print(Thread.currentThread().getContextClassLoader().getResource(“”));
print(CurrentDirectory.class.getClassLoader().getResource(“”));
print(ClassLoader.getSystemResource(“”));
print(CurrentDirectory.class.getResource(“”));
print(CurrentDirectory.class.getResource(“/”));
print(new File(“”).getAbsolutePath());
print(System.getProperty(“user.dir”));
  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Hive 是一个基于 Hadoop 的数据仓库系统,能够处理大规模的结构化数据。在 Hive 中使用自定义函数或者存储过程时,常常需要通过加载 jar 包来实现。以下三种方式是常用的 Hive 加载 jar 包的方式。 1. 添加 Hive AUX JARS 在 hive-site.xml 或者 hive-config.sh 中,通过配置 hive.aux.jars.path=xxxx 指定 jar 包存储的路径,最终将 jar 包添加到 Hadoop 的 ClassPath 中。当 Hive 运行需要加载 jar 包的任务时,就会从 ClassPath 中加载 jar 包,避免手动指定 JAR 文件。 2. ADD JAR 命令 使用 ADD JAR 命令将 jar 包添加到 Hive 会话中,可以通过全路径、本地路径或 Hadoop HDFS 路径来指定。例如 ADD JAR hdfs:///example/hive/hive-test.jar; 3. 使用命令行参数 启动 Hive 命令时,可以通过指定 –hiveconf hive.aux.jars.path=xxxx 指定 JAR 文件的路径,启动 Hive 命令同时就会将 JAR 文件加入到 ClassPath 中。 总之,在使用 Hive时,要根据实际情况选择合适的方式加载 JAR 包,避免出现错误。 ### 回答2: 在Hive中加载jar包有多种方式,以下列举其中三种: 1. 添加hive自定义类路径 在hive-site.xml文件中,将Hive的自定义类路径hive.aux.jars.path设置成需要加载的jar包所在路径,即可将jar包加入Hive的classpath中,方便调用自定义函数等操作。示例: <property> <name>hive.aux.jars.path</name> <value>/path/to/jar1:/path/to/jar2</value> </property> 2. 使用ADD JAR命令 在Hive的交互式终端或执行脚本时,使用ADD JAR命令将需要加载的jar包添加到Hive的classpath中。该命令会将jar包复制到Hive的临时文件夹中,可以通过system:java.io.tmpdir查看该路径。示例: ADD JAR /path/to/jar1; ADD JAR /path/to/jar2; 3. 在创建自定义函数时指定jar包路径 在创建自定义函数时,可以将需要加载的jar包路径直接指定到函数的CLASSPATH选项中。示例: CREATE TEMPORARY FUNCTION my_func AS 'com.package.MyFunc' USING JAR '/path/to/jar1'; 以上三种方式中,第一种和第二种可以将jar包持久地添加到Hive的classpath中,方便后续多个脚本或交互式终端使用;第三种方式则适用于只在当前会话使用自定义函数的情况。 ### 回答3: Hive 是一个基于 Hadoop 的数据仓库工具,它可以将结构化的数据以 SQL 的方式进行查询和分析。在 Hive 中,用户可以使用自定义的 UDF(用户定义函数),以扩展 Hive 的功能。 说到加载 Jar 包,Hive 有以下几种方式: 1. ADD JAR:通过 ADD JAR 命令将本地路径的 Jar 包加载到 Hive 中。 例如: ADD JAR /usr/local/hive/UDF/hive-udf.jar; 2. ADD ARCHIVE:通过 ADD ARCHIVE 命令将一个包含多个 Jar 包的 tar.gz 归档文件加载到 Hive 中。 例如: ADD ARCHIVE /usr/local/hive/UDF/hive-udf.tar.gz; 3. 在 Hive 配置文件中添加 Jar 包路径:在 Hive 的配置文件中,添加 Jar 包所在的路径,如下: hive.aux.jars.path=file:///usr/local/hive/UDF/hive-udf.jar 4. 使用命令行选项 "-hiveconf":在启动 Hive 前,使用 -hiveconf 命令行选项指定 Jar 包路径。 例如: $ hive -hiveconf hive.aux.jars.path=file:///usr/local/hive/UDF/hive-udf.jar 以上是 Hive 加载 Jar 包的几种方式,根据不同的需求,选择合适的方式即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值