Android学习笔记:NDK入门一些总结

1、安装

下载NDK包后,放到与SDK同级的目录下,并且配置好环境变量,配好后,在终端输入ndk-build命令测试,出现如下情况,则代表安装成功

2、工程与代码

a、新建android工程,编写java代码,写好需要的本地方法,以及加载的c文件名字

b、根据写好的java代码,生成.h的c文件,其中生成.h文件的步骤如下:

1、进入该项目的目录下

braincol@ubuntu:~$ cd workspace/android/NDK/hello-jni/

2、ls查看工程文件

braincol@ubuntu:~/workspace/android/NDK/hello-jni$ ls
AndroidManifest.xml assets bin default.properties gen res src

3、在工程目录下建立一个jni文件夹:

braincol@ubuntu:~/workspace/android/NDK/hello-jni$ mkdir jni
braincol@ubuntu:~/workspace/android/NDK/hello-jni$ ls
AndroidManifest.xml assets bin default.properties gen jni res src

4、执行如下语句就可以生成相应的.h文件了:

braincol@ubuntu:~/workspace/android/NDK/hello-jni$ javah -classpath bin -d jni com.example.hellojni.HelloJni

c、根据b中生成好的.h文件来编写相应的.c文件,根据自己的需要实现.h文件中的方法

d、编写Android.mk文件,其格式为如下:

e、生成.so共享库文件,在终端进入到该项目的目录下,输入ndk-build命令,即可在lib目录下生成.so文件,运行该项目,即可。

3、调试语句输出

在 NDK 中, printf() 没法输出,所以我们需要借助 log 库来将我们 c 代码库中需要输出的内容,通过 java 控制台输出。调用函数 __android_log_print(), 就可以在 Eclipse 中,查看 LogCat 来查看相关的输出信息了。

于是在c文件的编写中,需要引入android/log.h文件:

#include <android/log.h>

同时声明打印方法:

#define __android_log_print(......);例如:

因为打印是链接的log库,所以在Android.mk文件中加上如下一句:

LOCAL_LDLIBS += -llog

重新ndk-build,运行项目,可以在logcat中发现我们在c文件中加的打印语句。

参考:

http://www.cnblogs.com/hibraincol/archive/2011/05/30/2063847.html

http://blog.csdn.net/xuxinyl/article/details/6409030

你可能感兴趣的:(Android学习)