Javah 常见错误记录-NDK与JNI除错

来源:互联网 发布:关于网络喷子的见解 编辑:程序博客网 时间:2024/04/29 21:23
 测试文件:hello-jni/src/com/example/hellojni/HelloJni.java
[Java] view plaincopy
  1. /** 
  2.  * 该文件来自 Android NDK Sample - HelloJni, 为了便于说明问题,我作了一些修改。 
  3.  */  
  4. package com.example.hellojni;  
  5.   
  6. public class HelloJni  
  7. {  
  8.     public native String  stringFromJNI();  
  9.   
  10.     public native String  unimplementedStringFromJNI();  
  11.   
  12.     static {  
  13.         System.loadLibrary("hello-jni");  
  14.     }  
  15. }  

错误一

 

[Java] view plaincopy
  1. david@xmomx:hellojni$ javac HelloJni.java   
  2. david@xmomx:hellojni$ ls  
  3. Hello.class  Hello.h  Hello.java  HelloJni.class  HelloJni.java  
  4. david@xmomx:hellojni$ javah -jni HelloJni  
  5. error: cannot access HelloJni  
  6. bad class file: ./HelloJni.class  
  7. class file contains wrong class: com.example.hellojni.HelloJni  
  8. Please remove or make sure it appears in the correct subdirectory of the classpath.  
  9. com.sun.tools.javac.util.Abort  
  10.     at com.sun.tools.javac.comp.Check.completionError(Check.java:164)  
  11.     at com.sun.tools.javadoc.DocEnv.loadClass(DocEnv.java:149)  
  12.     at com.sun.tools.javadoc.RootDocImpl.<init>(RootDocImpl.java:77)  
  13.     at com.sun.tools.javadoc.JavadocTool.getRootDocImpl(JavadocTool.java:159)  
  14.     at com.sun.tools.javadoc.Start.parseAndExecute(Start.java:330)  
  15.     at com.sun.tools.javadoc.Start.begin(Start.java:128)  
  16.     at com.sun.tools.javadoc.Main.execute(Main.java:66)  
  17.     at com.sun.tools.javah.Main.main(Main.java:147)  
  18. javadoc: error - fatal error  
  19. 2 errors  

错误原因,没有在正确的路径下执行 javah 命令,应该在源码根目录下执行。

错误二:

 

[Java] view plaincopy
  1. david@xmomx:hellojni$ cd ../../../  
  2. david@xmomx:src$ ls  
  3. com  
  4. david@xmomx:src$ javah -jni HelloJni  
  5. error: cannot access HelloJni  
  6. class file for HelloJni not found  
  7. javadoc: error - Class HelloJni not found.  
  8. Error: No classes were specified on the command line.  Try -help.  

错误原因:Classes 参数要使用完整类名,也就是说要加上包名

错误四:

 

[Java] view plaincopy
  1. david@xmomx:src$ javah -jni com/example/hellojni/HelloJni  
  2. javadoc: error - Illegal package name: "com/example/hellojni/HelloJni"  
  3. 1 error  

错误原因:完整类名格式错误

 

[Java] view plaincopy
  1. david@xmomx:src$ javah -jni com.example.hellojni.HelloJni  

OK,编译通过。

如果还有错误,说是类找不到还是什么的,请尝试添加 -classpath . 参数。如下:

 

[Java] view plaincopy
  1. david@xmomx:src$ javah -jni -classpath . com.example.hellojni.HelloJni