最近在看Hadoop的源码,发现在用 hadoop jar *.jar 这个命令的时候调用RunJar这个类,在这个类里面用到了Manifest这个东西,于是乎学习了一下,只是简单的学习了一下。
先说下jar文件,也就是jar包实际上就是一个zip压缩文件(为什么是zip,下文介绍),这个压缩文件里面就是java的class文件,此外每一个jar包里面都有一个名为META-INF的文件夹,在这个文件夹里面有一个名为MANIFEST.MF的文件,这个文件实际上保存的就是这个jar包的一些标签信息,当运行一个jar文件时,会首先去读取这个文件获得class文件执行的一些信息。MANIFEST.MF形如:
Manifest-Version: 1.0
Ant-Version: Apache Ant 1.9.3
Created-By: 1.6.0_65-b14-462-11M4609 (Apple Inc.)
Main-Class: org.apache.tools.ant.Main
Name: org/apache/tools/ant/
Extension-name: org.apache.tools.ant
Specification-Title: Apache Ant
Specification-Version: 1.9.3
Specification-Vendor: Apache Software Foundation
Implementation-Title: org.apache.tools.ant
Implementation-Version: 1.9.3
Implementation-Vendor: Apache Software Foundation
如上所示,都是以“属性: 值”的形式保存的,这些信息里面最重要的是Main-Class这个属性,因为在