android的ndk学习(1)
来源:互联网 发布:3d发型设计软件 编辑:程序博客网 时间:2024/06/06 17:55
android的ndk学习(1)
之前学了一段时间ndk,总觉得要总结一下。ndk使得非常方便地实现java和C与C++代码的相互沟通,合理地掌握使用ndk可以提高应用程序的执行效率,所以对于学习anndroid开发的人来说,ndk是必须掌握的工具。刚刚开始学习的时候是有点兴奋,有点害怕的,兴奋是因为之前学过C++语言,能将学过的东西结合在一起,感觉可以做出更好的东西,害怕的是之前听身边的大神说ndk在android开发中是非常难的内容之一。但是不管怎么说我还是找了本书,看了视频,找了一些电子资料,并且开始了学习ndk之路!
一,第一个程序Hello world
相对来说,使用ndk实现大量的原生方法并让他们与Java类同步很容易成为一个繁琐的任务。首先需要新建一个android项目,然后在主函数那里声明一个native方法,代码如下
public class MainActivity extends Activity {public static native String test(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); }
然后使用命令行,开始-cmd,切换到项目的src目录下再执行命令如下:
javah -d ../jni 包名.MainActivity这时候刷新项目就会发现多了一个jni文件夹,里面有个.h的文件,打开就是一个c头文件
/* DO NOT EDIT THIS FILE - it is machine generated */#include <jni.h>/* Header for class com_example_exercise_MainActivity */#ifndef _Included_com_example_exercise_MainActivity#define _Included_com_example_exercise_MainActivity#ifdef __cplusplusextern "C" {#endif#undef com_example_exercise_MainActivity_MODE_PRIVATE#define com_example_exercise_MainActivity_MODE_PRIVATE 0L#undef com_example_exercise_MainActivity_MODE_WORLD_READABLE#define com_example_exercise_MainActivity_MODE_WORLD_READABLE 1L#undef com_example_exercise_MainActivity_MODE_WORLD_WRITEABLE#define com_example_exercise_MainActivity_MODE_WORLD_WRITEABLE 2L#undef com_example_exercise_MainActivity_MODE_APPEND#define com_example_exercise_MainActivity_MODE_APPEND 32768L#undef com_example_exercise_MainActivity_MODE_MULTI_PROCESS#define com_example_exercise_MainActivity_MODE_MULTI_PROCESS 4L#undef com_example_exercise_MainActivity_MODE_ENABLE_WRITE_AHEAD_LOGGING#define com_example_exercise_MainActivity_MODE_ENABLE_WRITE_AHEAD_LOGGING 8L#undef com_example_exercise_MainActivity_BIND_AUTO_CREATE#define com_example_exercise_MainActivity_BIND_AUTO_CREATE 1L#undef com_example_exercise_MainActivity_BIND_DEBUG_UNBIND#define com_example_exercise_MainActivity_BIND_DEBUG_UNBIND 2L#undef com_example_exercise_MainActivity_BIND_NOT_FOREGROUND#define com_example_exercise_MainActivity_BIND_NOT_FOREGROUND 4L#undef com_example_exercise_MainActivity_BIND_ABOVE_CLIENT#define com_example_exercise_MainActivity_BIND_ABOVE_CLIENT 8L#undef com_example_exercise_MainActivity_BIND_ALLOW_OOM_MANAGEMENT#define com_example_exercise_MainActivity_BIND_ALLOW_OOM_MANAGEMENT 16L#undef com_example_exercise_MainActivity_BIND_WAIVE_PRIORITY#define com_example_exercise_MainActivity_BIND_WAIVE_PRIORITY 32L#undef com_example_exercise_MainActivity_BIND_IMPORTANT#define com_example_exercise_MainActivity_BIND_IMPORTANT 64L#undef com_example_exercise_MainActivity_BIND_ADJUST_WITH_ACTIVITY#define com_example_exercise_MainActivity_BIND_ADJUST_WITH_ACTIVITY 128L#undef com_example_exercise_MainActivity_CONTEXT_INCLUDE_CODE#define com_example_exercise_MainActivity_CONTEXT_INCLUDE_CODE 1L#undef com_example_exercise_MainActivity_CONTEXT_IGNORE_SECURITY#define com_example_exercise_MainActivity_CONTEXT_IGNORE_SECURITY 2L#undef com_example_exercise_MainActivity_CONTEXT_RESTRICTED#define com_example_exercise_MainActivity_CONTEXT_RESTRICTED 4L#undef com_example_exercise_MainActivity_RESULT_CANCELED#define com_example_exercise_MainActivity_RESULT_CANCELED 0L#undef com_example_exercise_MainActivity_RESULT_OK#define com_example_exercise_MainActivity_RESULT_OK -1L#undef com_example_exercise_MainActivity_RESULT_FIRST_USER#define com_example_exercise_MainActivity_RESULT_FIRST_USER 1L#undef com_example_exercise_MainActivity_DEFAULT_KEYS_DISABLE#define com_example_exercise_MainActivity_DEFAULT_KEYS_DISABLE 0L#undef com_example_exercise_MainActivity_DEFAULT_KEYS_DIALER#define com_example_exercise_MainActivity_DEFAULT_KEYS_DIALER 1L#undef com_example_exercise_MainActivity_DEFAULT_KEYS_SHORTCUT#define com_example_exercise_MainActivity_DEFAULT_KEYS_SHORTCUT 2L#undef com_example_exercise_MainActivity_DEFAULT_KEYS_SEARCH_LOCAL#define com_example_exercise_MainActivity_DEFAULT_KEYS_SEARCH_LOCAL 3L#undef com_example_exercise_MainActivity_DEFAULT_KEYS_SEARCH_GLOBAL#define com_example_exercise_MainActivity_DEFAULT_KEYS_SEARCH_GLOBAL 4L/* * Class: com_example_exercise_MainActivity * Method: test * Signature: ()Ljava/lang/String; */JNIEXPORT jstring JNICALL Java_com_example_exercise_MainActivity_test (JNIEnv *, jclass);/* * Class: com_example_exercise_MainActivity * Method: updateFile * Signature: (Ljava/lang/String;)V */<pre name="code" class="java">JNICALL Java_com_example_exercise_MainActivity_updateFile (JNIEnv *, jclass, jstring)#ifdef __cplusplus}#endif#endif
代码很长,但是我们暂时只要看
JNICALL Java_com_example_exercise_MainActivity_updateFile (JNIEnv *, jclass, jstring)这就是根据我们一开始在mainactivity定义的那个native方法生成的一个方法。有了头文件,我们就可以开始写.c文件了,即实现文件,新建一个文件main.c,然后输入代码如下
#include<stdio.h>#include<stdlib.h>JNIEXPORT jstring JNICALL Java_com_example_exercise_MainActivity_test(JNIEnv * env, jobject obj){return (*env)->NewStringUTF(env, "Hello world !");}
返回一个字符串,这就是java与c交互的代码。
但是现在还不能直接运行,还要新建一个android.mk文件对项目进行配置,代码如下:
LOCAL_PATH :=$(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := mainLOCAL_SRC_FILES := main.cinclude $(BUILD_SHARED_LIBRARY)
好了,然后就是在mainactivity中使用方法了,代码如下
public class MainActivity extends Activity {public static native String test(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); TextView t = (TextView)findViewById(R.id.jnitextview); t.setText(test()); } static {System.loadLibrary("main");} }
导入库是使用的
static {System.loadLibrary("main");}main是我们在android.mk中配置的一个名字,现在万事俱备,只差编译生成so文件了,我们打开cmd并且切换到项目的目录下,执行ndk-build,中间是减号,不是下划线,刷新项目就可以看到libs中多了个文件夹和里面的一个libmain.so文件,这时候就可以运行项目了!如果没有意外就会出现helloworld在手机频幕上。
二,打印log
打印log是必须掌握的只是,所以这里介绍一下怎么配置,首先是配置android.mk文件,添加一行代码LOCAL_LDLIBS += -llog
完整的android.mk代码如下
LOCAL_PATH :=$(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := mainLOCAL_SRC_FILES := main.cLOCAL_LDLIBS += -lloginclude $(BUILD_SHARED_LIBRARY)
然后在实现文件中添加头文件#include<android/log.h>
并且宏定义要打印log的类型
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, "native-activity", __VA_ARGS__))
#define LOGW(...) ((void)__android_log_print(ANDROID_LOG_WARN, "native-activity", __VA_ARGS__))
#define LOGW(...) ((void)__android_log_print(ANDROID_LOG_WARN, "native-activity", __VA_ARGS__))
在代码中使用LOGI()或者LOGW,运行程序,然后就可以打印log了!更加详细的可以去看java api文档中的ndk篇。
三,总结
刚开始学jni,要配置这个要配置那个的非常麻烦,但是写了一个helloworld以后感觉配置也就那样,万事开头难啊!相信后面的学习会越来越难,但是也会越来越有意思,希望继续加油!
0 0
- android的ndk学习(1)
- Android的NDK学习1
- Android的NDK学习1
- android NDK的学习
- Android NDK 的学习
- Android NDK的入门学习
- Android NDK学习(1) 简介
- NDK学习(1)
- Android NDK学习(7)NDK测试时遇到的问题:C与C++互相调用
- Android NDK开发学习:我的第一个NDK项目
- Android NDK(1)
- Android NDK学习--编译和调试(Ubuntu+Eclipse+NDK)
- Android NDK学习教程(一)--第一个NDK程序
- Android NDK 的学习之旅-----数据传输
- Android NDK的入门学习过程
- Android-JNI NDK的学习记录
- Android NDK的入门学习Hello JNI
- 基于android NDK的初步学习
- POJ 3067 Japan(BIT)
- 工业4.0会给未来带来多大的改变?
- AndroidJNI.SetStaticBooleanField设置静态布尔域
- Python:列表生成式
- linux 磁盘操作命令
- android的ndk学习(1)
- 用日志记录Linux用户执行的每一条命令(history)
- 小菜鸟的xmpp(一)openfire安装 status 一直stop 打开不了
- How to run application in Qt as administrator?
- 并没有那个艰难,但也并没有那么简单
- 适配器模式
- ImageView 长按保存
- Android通过反射打造可以存储任何对象的万能SharedPreferences
- POJ1094 Sorting It All Out 拓扑排序(深搜)