1·创建一个android工程,配置NDK编译环境,path路径等,声明本地方法:例如
public native String sayHello();
2·添加本地方法支持.右键工程。AndroidTools
3·使用javah生成.h头文件,并把生成的.h文件copy到jni目录下面
javah -jni 本地方法所在的全类名(-jni可以省略)
(注意这里存在jdk1.6跟1.7的问题)
1.6在当前工程的bin/classes下执行javah命令
1.7在当前工程的src目录下执行上命令
4·在jni下面建立一个.c文件,添加文件头,也可直接引用3步生成的头文件替换#include<jni.h>,但是注意是#include".....h"本地引用
#include<stdio.h>
#include<stdlib.h>
#include<jni.h>
jstring Java_com_example_testjni1_MainActivity_sayHello(JNIEnv* env,jobject jobj){
return (*env)->NewStringUTF(env,"I am from C");
}
//返回jstring:就是java里面的String
Java_com_example_testjni1_MainActivity_sayHello:Java_全类名(. ---> _ )_方法名
特别注意别名定义:
typedef const struct JNINativeInterface* JNIEnv;
也就是说const struct JNINativeInterface* 的别名是JNIEnv,
那么JNIEnv* 也就表示 const struct JNINativeInterface**
即:
(env)->NewStringUTF 等价于(*env). NewStringUTF
jobject jobj:jobj表示谁调用代表谁的实例,比如现在就是MainActivity.this
5·在jni下面建立一个Android.mk文件
#初始化工具链的函数,当前的作用是得到当前文件目录
LOCAL_PATH := $(call my-dir)
#清空和初始化工具链,注意:不会清空LOCAL_PATH的配置,但会清空下面的LOCAL_变量对应的参数
include $(CLEAR_VARS)
#配置动态链接库的名称,名称前面省略lib,后缀不能加.so
LOCAL_MODULE := liuyi //System.loadLibrary("liuyi");保持一致
LOCAL_SRC_FILES := Hello.c //C文件的名称,多个c文件可以加个空格连续写,比如:LOCAL_SRC_FILES := Hello.c Hello2.c
#配置动态链接库BUILD_SHARED_LIBRARY,生成.so文件,文件体积小(通常这么写)
#配置静态链接库BUILD_STATIC_LIBRARY,生成.a文件,文件体积大
include $(BUILD_SHARED_LIBRARY)
6·在jni下面建立一个Application.mk文件
APP_ABI := armeabi #armeabi armeabi-v7a x86等,所有就用all
7·
static{
System.loadLibrary("liuyi"); //LOCAL_MODULE := liuyi保持一致
}
8.ndk-build生成.so文件。
9.查看方法签名:
找到所需方法的类的.class文件
eclipse的文件在工程目录\bin\classes目录中,例如
TestJni\bin\classes\com\example\text\MainActivity.class
Android Studio的文件在工程目录app\build\intermediates\classes中,例如
TestJni\app\build\intermediates\classes\debug\com\dreamori\testjni\MainActivity.class
javap -s KBServer.class
附加快捷方式:
在windows平台下,按着shift键然后右击鼠标。。。。在此处打开命令窗口(perfect)