Jar 打包与执行
Java学习笔记之一,用于个人记录。整理自《Head First Java》。
假设有如下目录结构:

程序入口在 Jukebox8.java。这个代码文件开头是有如下这样的包声明语句的:
package com.headfirstjava;
先进入到源码所在目录:
cd MyProject/source
1. 编译:
javac -d ../classes com/headfirstjava/Jukebox8.java
编译后会在classes目录下自动生成com目录,以及com下面的headfirstjava目录,并把相关的.class文件放在这个目录下:

2. 执行
cd MyProject/classes
java com.headfirstjava.Jukebox8
3. 创建JAR
3.1 要求:
- 所有相关的类文件都放在 class 目录下相对应的包结构当中
- 创建 manifest.txt 文件来描述哪个类带有 main(),格式如下:
Main-Class: com.headfirstjava.Jukebox8
当前环境下,要把 manifest.txt 文件放到 classes 目录下
3.2 执行 jar 命令创建 JAR 文件
cd MyProject/classes
jar -cvmf manifest.txt packEx.jar com
jar 是一个可执行命令
-cvmf 是 jar 命令可接受的参数
- c 表示 create,创建一个新的归档文件
- v 表示 verbose,在标准输出中显示创建过程
- m 表示指定 manifest 文件
- f 指定新的归档文件的名字
packEx.jar 是生成之后的 JAR 文件的名字,这个名字可以随便起的
com 表示要打包的文件夹,也即是项目的类文件所在的地方
上述命令执行完后,生成的 JAR 文件会放在当前目录下。为了方便起见,先把生成的 packEx.jar 文件移动到一个叫 Skyler 的新目录下
4. 解压
解压可以直接用一般的压缩软件来解压,就像解压 zip 压缩包一样
4.1 查看JAR文件的内容:
cd Skyler
jar -tf packEx.jar
- t 表示 table,即用表格的形式把归档文件中的文件列出来
- f 同前述,指定文件
4.2 解压 JAR 文件
jar -xf packEx.jar
- x 表示 eXtract,即提取
- f 同前述,指定文件
执行完后会生成两个目录,结构如下:

在META-INF目录下,有一个MANIFEST.MF文件,里面其实就相当于原来的 manifest.txt 的内容,不过更加丰富了。
而在com目录下,则与打包前的内容是一样的
5. 执行 JAR 包
java -jar packEx.jar
Jar 打包与执行的更多相关文章
- jar 打包后的文件执行时出现错误:RunJar jarFile [mainClass] args...
修改别人的jar包中的配置文件,然后再打包后执行出错:RunJar jarFile [mainClass] args... 经过分析,是因为打包时需要设置mainClass,可以通过如下方法: jar ...
- windows10计划任务启动bat执行jar打包的jar文件
今天公司要用bat文件执行jar打包的java文件,运行没项目的程序,并且用任务计划开机自启,今天记录下坑 系统:win10 一.编写.bat执行用jar打包的jar文件 @echo off java ...
- SpringBoot+Maven多模块项目(创建、依赖、打包可执行jar包部署测试)完整流程
一,创建Maven多模块项目先建立外层父工程 File →new →project 选择Spring Initializr Next下一步到以下页面 工程结构如下 ...
- maven打包可执行jar文件运行报错
起因 项目中同时依赖了Spring和MyBatis,并使用mybatis-spring集成MyBatis和Spring. 使用maven打包为可执行jar文件运行,打包插件为:maven-shade- ...
- spring boot项目maven打包可执行JAR
在pom.xml中添加如下配置: <!-- 打包可执行jar包 --> <plugin> <groupId>org.springframework.boot< ...
- springboot打包的问题可执行jar和不可执行jar
具体解释可以参看:https://www.cnblogs.com/liaojie970/p/9007577.html 如果只是想要依赖那么可以将springboot自带的打包插件换掉就可以了,换为如下 ...
- Apache Maven 打包可执行jar
在本文的 参考资料 部分,您将发现大量介绍 Maven 的入门教程.本文的 5 个技巧目的是帮助您解决即将出现的一些问题:使用 Maven 管理您的应用程序的生命周期时,将会出现的编程场景. 1. 可 ...
- idea打包 - 可执行jar包
需求:有一个基于SpringBoot的socket服务端程序,实现了对消息的接收.发送并行操作.此时想要将其构建成可执行的Jar包,执行 java -jar xx.jar后能够进行消息的收发. 分析: ...
- java基础篇-jar打包
以helloworld程序为例: 一:正常流程: 1.首先编写一个hello.java的程序: public class Hello { public static void main(String[ ...
随机推荐
- Winform中自定义ZedGraph右键复制成功后的提示
场景 Winform中实现ZedGraph中曲线右键显示为中文: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/100115292 ...
- pycharm2019.2一个奇怪的bugger,执行后输出内容被莫名处理
2019-08-20 07:45:07 python爬虫是一直来大家都用的多的,我也是常常用到. requests做请求方便的很,但是今天却遇到requests的bug.text内容不可信. pych ...
- [UIApplication sharedApplication].keyWindow.rootViewController
一般来说 [UIApplication sharedApplication].keyWindow.rootViewController 会在 appDelegate 中初始化,并且整个应用运行过程中都 ...
- SparkStreaming和storm的区别
这是2种不同的架构. 他们的区别是SparkStreaming的吞吐量非常高,秒级准实时处理,Storm是容错性非常高,毫秒级实时处理 解释:sparkStreaming是一次处理某个间隔的数据,比如 ...
- [20191010]bash行计算器.txt
[20191010]bash行计算器.txt --//写一个bash行计算器,为了避免冲突,函数命名为2个=,1个=感觉不是很好(心里上^_^).--//使用bc计算器,里面函数不能使用圆括号,使用中 ...
- scrapy简单使用方法
scrapy简单使用方法 1.创建项目:scrapy startproject 项目名例如:scrapy startproject baike windows下,cmd进入项目路径例如d:\pytho ...
- spark 基础
scala版 ,基本名词概念及 rdd的基本创建及使用 var conf = new SparkConf() var sc: SparkContext = new SparkContext(conf) ...
- 解构如何运用的解构--报错 throw new TypeError('Router.use() requires a middleware function but got a ' + gettype(fn))
let aa={ error_code: 0, reason: "插入数据成功" };//如何拿到 error_code 和 reason 的值 let { error_code, ...
- IOS HTML点击时有背景阴影
在写H5时, IOS上的div点击会出现阴影, 如何去掉阴影呢? 在div的css属性中添加下面一条: -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
- day3_7.1
1.python的注释 python中为了使代码更容易被人看懂,提高团队开发效率,可使用注释.代码中的注释不加入编译中. 注释有单行注释,如 #这是一段注释 和多行注释: ''' 这是一行注释 ''' ...