********************************************************************************
用javah 导出类的头文件, 常见的错误及正确的使用方法
********************************************************************************
正确的使用方法是:
1. 类名要使用全路径类名,不带扩展名
2. 自己要处于合适的目录,
3. 正确设置工作类路径
4. 正确设定系统类路经。
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>javah HelloJNIActivity.class
Exception in thread "main" java.lang.IllegalArgumentException: Not a valid class name: HelloJNIActivity.class
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:177)
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:68)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:509)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:335)
at com.sun.tools.javah.Main.main(Main.java:46)
--------------------------------------------------------------------------------
comment by hjj: 不能指明扩展名.class
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>javah HelloJNIActivity
错误: 找不到 'HelloJNIActivity' 的类文件。
--------------------------------------------------------------------------------
comment by hjj: 类名称要用点分割的全称
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>javah test.hellojni.HelloJNIActivity
错误: 找不到 'test.hellojni.HelloJNIActivity' 的类文件。
--------------------------------------------------------------------------------
comment by hjj: 用全称,要与本地目录相配合
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah test.hellojni.HelloJNIActivity
错误: 无法访问android.app.Activity
找不到android.app.Activity的类文件
--------------------------------------------------------------------------------
comment by hjj: 很好! 找到了类文件, 但无法解析系统库文件
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah test.hello.jni.HelloJNIActivity -classpath
'c:\program files\Android\android-sdk\platforms\andr oid-16\android.jar'
Exception in thread "main" java.lang.IllegalArgumentException: Not a valid class name: -classpath
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:177)
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:68)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:509)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:335)
at com.sun.tools.javah.Main.main(Main.java:46)
--------------------------------------------------------------------------------
comment by hjj: 路径不能放到后面
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah -classpath
'c:\program files\Android\android-sdk\platforms\android-16\android.jar'
test.hellojn i.HelloJNIActivity Exception in thread "main" java.lang.IllegalArgumentException:
Not a valid class name: files\Android\android-sdk\platforms\android-16\android.jar'
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:177)
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:68)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:509)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:335)
at com.sun.tools.javah.Main.main(Main.java:46)
--------------------------------------------------------------------------------
comment by hjj: 含空格的路径不能用单引号,而应该用双引号括住
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah -classpath
"c:\program files\Android\android-sdk\platforms\android-16\android.jar" test.hellojni.HelloJNIActivity
错误: 找不到 'test.hellojni.HelloJNIActivity' 的类文件。
--------------------------------------------------------------------------------
comment by hjj: 类路径除需指明系统类路径,还需要指明工作路径。工作路径要与类全称相配合
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>cd ../../
D:\buffer\hellojni\HelloJNI\bin\classes>cd ..
D:\buffer\hellojni\HelloJNI\bin>cd ..
D:\buffer\hellojni\HelloJNI>javah -classpath
"c:\program files\Android\android-sdk\platforms\android-16\android.jar";bin/classes
test.hellojni.HelloJNIActivity
--------------------------------------------------------------------------------
comment by hjj: 成功
在当前目录:D:\buffer\hellojni\HelloJNI 生成 test_hellojni_HelloJNIActivity.h
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI> cd bin\classes
D:\buffer\hellojni\HelloJNI\bin\classes>javah -classpath
"c:\program files\Android\android-sdk\platforms\android-16\android.jar";. test.helljni.HelloJNIActivity
--------------------------------------------------------------------------------
comment by hjj: 成功
在当前目录:D:\buffer\hellojni\HelloJNI\bin\classes 生成 test_hellojni_HelloJNIActivity.h
--------------------------------------------------------------------------------
用javah 导出类的头文件, 常见的错误及正确的使用方法
********************************************************************************
正确的使用方法是:
1. 类名要使用全路径类名,不带扩展名
2. 自己要处于合适的目录,
3. 正确设置工作类路径
4. 正确设定系统类路经。
********************************************************************************
前言: 在 D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni> 下, 有一个class 文件叫HelloJNIActivity.class 目标文件
现在欲从这个class 文件导出类的头文件。
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>javah HelloJNIActivity.class
Exception in thread "main" java.lang.IllegalArgumentException: Not a valid class name: HelloJNIActivity.class
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:177)
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:68)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:509)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:335)
at com.sun.tools.javah.Main.main(Main.java:46)
--------------------------------------------------------------------------------
comment by hjj: 不能指明扩展名.class
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>javah HelloJNIActivity
错误: 找不到 'HelloJNIActivity' 的类文件。
--------------------------------------------------------------------------------
comment by hjj: 类名称要用点分割的全称
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>javah test.hellojni.HelloJNIActivity
错误: 找不到 'test.hellojni.HelloJNIActivity' 的类文件。
--------------------------------------------------------------------------------
comment by hjj: 用全称,要与本地目录相配合
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah test.hellojni.HelloJNIActivity
错误: 无法访问android.app.Activity
找不到android.app.Activity的类文件
--------------------------------------------------------------------------------
comment by hjj: 很好! 找到了类文件, 但无法解析系统库文件
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah test.hello.jni.HelloJNIActivity -classpath
'c:\program files\Android\android-sdk\platforms\andr oid-16\android.jar'
Exception in thread "main" java.lang.IllegalArgumentException: Not a valid class name: -classpath
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:177)
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:68)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:509)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:335)
at com.sun.tools.javah.Main.main(Main.java:46)
--------------------------------------------------------------------------------
comment by hjj: 路径不能放到后面
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah -classpath
'c:\program files\Android\android-sdk\platforms\android-16\android.jar'
test.hellojn i.HelloJNIActivity Exception in thread "main" java.lang.IllegalArgumentException:
Not a valid class name: files\Android\android-sdk\platforms\android-16\android.jar'
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:177)
at com.sun.tools.javac.api.JavacTool.getTask(JavacTool.java:68)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:509)
at com.sun.tools.javah.JavahTask.run(JavahTask.java:335)
at com.sun.tools.javah.Main.main(Main.java:46)
--------------------------------------------------------------------------------
comment by hjj: 含空格的路径不能用单引号,而应该用双引号括住
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes>javah -classpath
"c:\program files\Android\android-sdk\platforms\android-16\android.jar" test.hellojni.HelloJNIActivity
错误: 找不到 'test.hellojni.HelloJNIActivity' 的类文件。
--------------------------------------------------------------------------------
comment by hjj: 类路径除需指明系统类路径,还需要指明工作路径。工作路径要与类全称相配合
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI\bin\classes\test\hellojni>cd ../../
D:\buffer\hellojni\HelloJNI\bin\classes>cd ..
D:\buffer\hellojni\HelloJNI\bin>cd ..
D:\buffer\hellojni\HelloJNI>javah -classpath
"c:\program files\Android\android-sdk\platforms\android-16\android.jar";bin/classes
test.hellojni.HelloJNIActivity
--------------------------------------------------------------------------------
comment by hjj: 成功
在当前目录:D:\buffer\hellojni\HelloJNI 生成 test_hellojni_HelloJNIActivity.h
--------------------------------------------------------------------------------
D:\buffer\hellojni\HelloJNI> cd bin\classes
D:\buffer\hellojni\HelloJNI\bin\classes>javah -classpath
"c:\program files\Android\android-sdk\platforms\android-16\android.jar";. test.helljni.HelloJNIActivity
--------------------------------------------------------------------------------
comment by hjj: 成功
在当前目录:D:\buffer\hellojni\HelloJNI\bin\classes 生成 test_hellojni_HelloJNIActivity.h
--------------------------------------------------------------------------------