• Ubuntu下编译Android JNI实例全过程


    第一步:保证makegcc可用

    shell中输入make-v。不报错就是对的。(可參考http://wenku.baidu.com/view/d87586c24028915f804dc24a.html.

    shell中输入gcc-v,不报错就是对的。

    第二步:安装NDK

     下载NDK后。环境变量设置:

        android-ndk的路劲加到环境变量PATH中:sudogedit /etc/environment

       然后再让这个更改的环境变量马上生效:source /etc/environment

       经过了上述步骤,在命令行下敲:ndk-bulid(在个人用户下。不要在root下)

     弹出例如以下的错误。而不是说ndk-buildnot found,就说明ndk环境已经成功安装了。

        AndroidNDK: Could not find application project directory !    
        AndroidNDK: Please define the NDK_PROJECT_PATH variable to point toit.    
        /home/braincol/workspace/android/android-ndk-r5/build/core/build-local.mk:85:*** Android NDK: Aborting    .  Stop.

    第三步:编写Androidproject

      建立一个Android应用projectHelloJni。创建HelloJni.java文件:

      HelloJni.java:

    import android.app.Activity;
    import android.widget.TextView;
    import android.os.Bundle;
    
    public class HelloJni extends Activity
    {
        /** Called when the activity is first created. */
        @Override
        public void onCreate(Bundle savedInstanceState)
        {
            super.onCreate(savedInstanceState);
            TextView  tv = new TextView(this);
            tv.setText( stringFromJNI() );
            setContentView(tv);
        }
        /* A native method that is implemented by the 'hello-jni' native library, which is packaged with this application. */
        public native String  stringFromJNI();
    
        /* this is used to load the 'hello-jni' library on application startup. The library has already been unpacked into
          /data/data/com.example.HelloJni/lib/libhello-jni.so at installation time by the package manager. */
        static {
            System.loadLibrary("hello-h3c");
        }
    }

    第四步:用eclipse编译该project

       生成对应的.class文件,这步必须在下一步之前完毕,由于生成.h文件须要用到对应的.class文件。

    首先在project下新建一jni目录,打开终端;cd<project名>;运行:javah-classpath bin/classes -d jni XXX. HelloJni 就能够在jni下发现.h文件,当中xxx是包名。比方我的是cd /home/lck/workspace/HelloJni 运行:javah-classpath bin/classes -d jnicom.example.hellojni.HelloJni

    第五步:编写C代码

    jni下新建一个c文件。编写对应的.c文件:

    hello-h3c.c:

    #include <string.h>
    #include <jni.h>
    /* This is a trivial JNI example where we use a native method
    
     * to return a new VM String. See the corresponding Java source
    
     * file located at:
    
     *   apps/samples/hello-jni/project/src/com/example/HelloJni/HelloJni.java
    
     */
    jstring Java_com_example_h3cjni_HelloJni_stringFromJNI( JNIEnv* env, jobject thiz )
    {
        return (*env)->NewStringUTF(env, "Hello from H3c !");
    }

    第六步:编写Android.mk文件

    jni目录下新建一个Android.mk文件。

    里面加入例如以下内容:

    LOCAL_PATH := $(call my-dir)
    include $(CLEAR_VARS)
    
    LOCAL_MODULE := hello-h3c
    LOCAL_SRC_FILES := hello-h3c.c
    
    include $(BUILD_SHARED_LIBRARY)
    对于=号左边符号的意思,百度上有非常多解释,在这里就不介绍了。

    第七步:生成.so共享库文件

    cd<project名>。运行ndk-build,假设发现

    [armeabi]Install : libhello-h3c.so => libs/armeabi/libhello-h3c.so

    即生成了.so文件。我们能够在libs/armeabi/文件夹下找到该文件

    此时执行安卓project,我们能够在模拟器上看到。右图界面

    注意:第七步完毕后执行。easy出现java.lang.UnsatisfiedLinkError错误,这样的错误往往是因为方法名的大写和小写或者引用出错。比方,我用的别人的样例,在c文件里jstringJava_com_example_h3cjni_HelloJni_stringFromJNI( JNIEnv* env, jobjectthiz )

    应改为jstringJNICALLJava_com_example_hellojni_HelloJni_stringFromJNI,所以引用一定要正确。



    參考博客:http://blog.csdn.net/h3c4lenovo/article/details/10364679








  • 相关阅读:
    nodejs+mongoose操作mongodb副本集实例
    创建mongodb副本集操作实例
    SpringBoot(二)Web整合开发
    SpringBoot(一)走进Springboot的世界
    Git(二)Git几个区的关系与Git和GitHub的关联
    Git(一)之基本操作详解
    HttpClient(二)HttpClient使用Ip代理与处理连接超时
    HttpClient(一)HttpClient抓取网页基本信息
    Jsoup(一)Jsoup详解(官方)
    MongoDB(一)环境搭建与初始配置
  • 原文地址:https://www.cnblogs.com/yxysuanfa/p/7199013.html
Copyright © 2020-2023  润新知