Android问题集锦转载之三 Javah 常见错误记录-NDK与JNI除错

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

               

测试文件:hello-jni/src/com/example/hellojni/HelloJni.java

  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. }  
/** * 该文件来自 Android NDK Sample - HelloJni, 为了便于说明问题,我作了一些修改。 */package com.example.hellojni;public class HelloJni{    public native String  stringFromJNI();    public native String  unimplementedStringFromJNI();    static {        System.loadLibrary("hello-jni");    }}

错误一

  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  
david@xmomx:hellojni$ javac HelloJni.java david@xmomx:hellojni$ lsHello.class  Hello.h  Hello.java  HelloJni.class  HelloJni.javadavid@xmomx:hellojni$ javah -jni HelloJnierror: cannot access HelloJnibad class file: ./HelloJni.classclass file contains wrong class: com.example.hellojni.HelloJniPlease remove or make sure it appears in the correct subdirectory of the classpath.com.sun.tools.javac.util.Abort at com.sun.tools.javac.comp.Check.completionError(Check.java:164) at com.sun.tools.javadoc.DocEnv.loadClass(DocEnv.java:149) at com.sun.tools.javadoc.RootDocImpl.<init>(RootDocImpl.java:77) at com.sun.tools.javadoc.JavadocTool.getRootDocImpl(JavadocTool.java:159) at com.sun.tools.javadoc.Start.parseAndExecute(Start.java:330) at com.sun.tools.javadoc.Start.begin(Start.java:128) at com.sun.tools.javadoc.Main.execute(Main.java:66) at com.sun.tools.javah.Main.main(Main.java:147)javadoc: error - fatal error2 errors

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

错误二:

扫描二维码关注公众号,回复: 4927740 查看本文章
  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.  
david@xmomx:hellojni$ cd ../../../david@xmomx:src$ lscomdavid@xmomx:src$ javah -jni HelloJnierror: cannot access HelloJniclass file for HelloJni not foundjavadoc: error - Class HelloJni not found.Error: No classes were specified on the command line.  Try -help.

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

错误四:

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

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

  1. david@xmomx:src$ javah -jni com.example.hellojni.HelloJni  
david@xmomx:src$ javah -jni com.example.hellojni.HelloJni

OK,编译通过。

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

  1. david@xmomx:src$ javah -jni -classpath . com.example.hellojni.HelloJni  
david@xmomx:src$ javah -jni -classpath . com.example.hellojni.HelloJni
           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow

这里写图片描述

猜你喜欢

转载自blog.csdn.net/yttyffggh/article/details/84194462