C clever_boy_2000 Unregistered / Unconfirmed GUEST, unregistred user! 2003-03-03 #1 请问各位DFW: 如何使使*.class文件变成*.jar文件, jdk中有命令么? 生成*.jar后又如何运行呢?
O only you Unregistered / Unconfirmed GUEST, unregistred user! 2003-03-03 #3 用法:jar {ctxu}[vfm0Mi] [jar-文件] [manifest-文件] [-C 目录] 文件名 ... 选项: -c 创建新的存档 -t 列出存档内容的列表 -x 展开存档中的命名的(或所有的〕文件 -u 更新已存在的存档 -v 生成详细输出到标准输出上 -f 指定存档文件名 -m 包含来自标明文件的标明信息 -0 只存储方式;未用ZIP压缩格式 -M 不产生所有项的清单(manifest〕文件 -i 为指定的jar文件产生索引信息 -C 改变到指定的目录,并且包含下列文件: 如果一个文件名是一个目录,它将被递归处理。 清单(manifest〕文件名和存档文件名都需要被指定,按'm' 和 'f'标志指定的相同顺序。 示例1:将两个class文件存档到一个名为 'classes.jar' 的存档文件中: jar cvf classes.jar Foo.class Bar.class 示例2:用一个存在的清单(manifest)文件 'mymanifest' 将 foo/ 目录下的所有 文件存档到一个名为 'classes.jar' 的存档文件中: jar cvfm classes.jar mymanifest -C foo/ .
用法:jar {ctxu}[vfm0Mi] [jar-文件] [manifest-文件] [-C 目录] 文件名 ... 选项: -c 创建新的存档 -t 列出存档内容的列表 -x 展开存档中的命名的(或所有的〕文件 -u 更新已存在的存档 -v 生成详细输出到标准输出上 -f 指定存档文件名 -m 包含来自标明文件的标明信息 -0 只存储方式;未用ZIP压缩格式 -M 不产生所有项的清单(manifest〕文件 -i 为指定的jar文件产生索引信息 -C 改变到指定的目录,并且包含下列文件: 如果一个文件名是一个目录,它将被递归处理。 清单(manifest〕文件名和存档文件名都需要被指定,按'm' 和 'f'标志指定的相同顺序。 示例1:将两个class文件存档到一个名为 'classes.jar' 的存档文件中: jar cvf classes.jar Foo.class Bar.class 示例2:用一个存在的清单(manifest)文件 'mymanifest' 将 foo/ 目录下的所有 文件存档到一个名为 'classes.jar' 的存档文件中: jar cvfm classes.jar mymanifest -C foo/ .
C clever_boy_2000 Unregistered / Unconfirmed GUEST, unregistred user! 2003-03-03 #4 to only you: 感谢你的光临, 1>比如我有一个tt.class在~/jdk/lib/下,如何使它变成tt.jar.并如何使他运行? 2>我有一个pakage(com),在~/jdk/lib/下,如何使它变成tt.jar.并如何使他运行? 谢谢
to only you: 感谢你的光临, 1>比如我有一个tt.class在~/jdk/lib/下,如何使它变成tt.jar.并如何使他运行? 2>我有一个pakage(com),在~/jdk/lib/下,如何使它变成tt.jar.并如何使他运行? 谢谢
L Lysjack Unregistered / Unconfirmed GUEST, unregistred user! 2003-03-03 #5 用同样的方法,加上目录就行了。 jar cvf tt.jar ~/jdk/lib/tt.class
O only you Unregistered / Unconfirmed GUEST, unregistred user! 2003-03-03 #6 jar cvfm tt.jar manifest.mf ~/jdk/lib/ 这里 tt.jar 和 manifest.mf 两个文件,分别是对应的参数 f 和 m, 要创建可执行的 JAR 文件包,要指定一个 manifest.mf 文件,但还是不够的, 因为 MANIFEST 是 JAR 文件包的特征,可执行的 JAR 文件包和不可执行的 JAR 文件包都包含 MANIFEST。关键在于可执行 JAR 文件包的 MANIFEST,其内容 包含了 Main-Class 一项。这在 MANIFEST 中书写格式如下: Main-Class: 可执行主类全名(包含包名),例如你的为tt 例如,假设上例中的 tt.class 是属于xxxxx包的,而且是可执行的类 (定义了 public static void main(String[]) 方法), 那么这个 manifest.mf 可以编辑如下: Main-Class: xxxxx.tt <回车> 这个 manifest.mf 可以放在任何位置, 也可以是其它的文件名, 只需要有 Main-Class: xxxxx.tt 一行, 且该行以一个回车符结束即可。 这样作出的jar文件即可用java -jar 运行 [red] 注:这个manifest.mf 文件可用任何文本编辑器自己编写 [/red]
jar cvfm tt.jar manifest.mf ~/jdk/lib/ 这里 tt.jar 和 manifest.mf 两个文件,分别是对应的参数 f 和 m, 要创建可执行的 JAR 文件包,要指定一个 manifest.mf 文件,但还是不够的, 因为 MANIFEST 是 JAR 文件包的特征,可执行的 JAR 文件包和不可执行的 JAR 文件包都包含 MANIFEST。关键在于可执行 JAR 文件包的 MANIFEST,其内容 包含了 Main-Class 一项。这在 MANIFEST 中书写格式如下: Main-Class: 可执行主类全名(包含包名),例如你的为tt 例如,假设上例中的 tt.class 是属于xxxxx包的,而且是可执行的类 (定义了 public static void main(String[]) 方法), 那么这个 manifest.mf 可以编辑如下: Main-Class: xxxxx.tt <回车> 这个 manifest.mf 可以放在任何位置, 也可以是其它的文件名, 只需要有 Main-Class: xxxxx.tt 一行, 且该行以一个回车符结束即可。 这样作出的jar文件即可用java -jar 运行 [red] 注:这个manifest.mf 文件可用任何文本编辑器自己编写 [/red]