博客
关于我
Android Studio NDK 如何生成so
阅读量:507 次
发布时间:2019-03-07

本文共 1120 字,大约阅读时间需要 3 分钟。

Android Studio NDK 如何生成so

先来看下代码

MyNdkUtil.java

package com.heiko.ndksotest;public class MyTestNdk {    static {        System.loadLibrary("native-lib");    }    public native String stringFromJNI();}

native-lib.cpp

#include 
#include
extern "C"JNIEXPORT jstring JNICALLJava_com_heiko_ndksotest_MyTestNdk_stringFromJNI(JNIEnv *env, jobject instance) { /*std::string hello = "Hello from C++ !"; return env->NewStringUTF(hello.c_str());*/ char* hello = "Hello from C++ !!"; return env->NewStringUTF(hello);}

接着,编译NDK项目

编译so

然后,在项目中找到so文件

找到so

接着,将so及MyTestNdk.java复制到另外的项目中使用

使用so

其中,MyTestNdk.java的包名必须与原报名一致。

值得一提的是,在正式的环境中,一般会将这些java文件打包成jar包,将jar及so文件直接提供给调用者使用。

最后,在MainActivity.java中调用并运行

public class MainActivity extends AppCompatActivity {    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        TextView tv = (TextView) findViewById(R.id.sample_text);        MyTestNdk myTestNdk = new MyTestNdk();        tv.setText(myTestNdk.stringFromJNI());    }}

App界面显示 Hello from C++ !!,至此调用成功。

你可能感兴趣的文章
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>