在windows上进行ndk开发.docx
《在windows上进行ndk开发.docx》由会员分享,可在线阅读,更多相关《在windows上进行ndk开发.docx(12页珍藏版)》请在冰豆网上搜索。
在windows上进行ndk开发
在windows做ndk开发
1、cygwin的安装和使用
1.1、什么是cygwin?
Cygwin是一个在windows上模拟linux和unix环境的仿真软件,安装cygwin之后你可以像使用linux那样使用windows。
1.2、cygwin在windows上安装了什么东西?
库->各种库函数,工具包,这一切都是都能在cygwin的安装目录下面能找到,你会在这个安装目录下找到一个类似linux文件系统结构的目录,
这是cygwin的安装目录对比你的linux目录你会发现非常相似,我的感觉是cygwin就是一个脱壳程序,当做一个工具就可以了。
1.3、安装与使用。
1.3.1、首先到下载cygwin的在线安装程序,下载页面
之后双击这个图标。
1.3.2、在弹出的界面选择下一步.
1.3.3、选择在线安装或本地安装,这里为了演示,选择了在线安装,实际上安装包我已经下载下来了。
1.3.4、选择安装路径
1.3.5、选择文件下载下来的的时候存放路径
1.3.6、选择联网方式
1.3.7选择下载地址的镜像,这个软件的在线安装地址在国外,但可以有镜像,选择一个好的镜像,下载速度会快的多。
1.3.8、开始下载安装。
1.3.9、下载完毕的时候会让你选择安装包
有由于我们只需要安装make和gcc下面的工具,而这些包都在Devel路径下,所以点击安安装就可以了,其他的包比如说ssh,vi,vim等可以选择安装,几乎linux所有的包都有的。
安装完成之后,会提示你在桌面或者开始菜单加入快捷图标,双击图标即可启动,如图
第一次启动会出现配置信息,这个不用管,实际上每次启动都比较慢,毕竟都要加载许多库文件,以保证能正常运行。
查看是否已经安装gcc和make工具
输入make和gcc命令,查看是否安装成功,入上图所示就ok了,否则重新安装吧。
2、编写native应用
2.1、编写javanative接口,入demo所示
packagecom.ndk.demo;
publicclassJNIDemo{
publicnativeintgetCint();
publicnativeStringgetCString();
}
其中,getCint和个体CString是需要用linuxc要实现的接口,
2.2、将这个java文件拷贝到工程的bin目录下,调用javac命令生成.class文件,注意一定要放到工程文件的bin目录下,否则ndk不能正常编译出c接口头文件。
2.3、将这个class文件放到bin对应包的目录下,同时调用javah命令生成头文件:
本例中命令如下:
Javah-jnicom.ndk.demo.JNIDemo
生成的借口定义.h文件如下:
/*DONOTEDITTHISFILE-itismachinegenerated*/
#include
/*Headerforclasscom_ndk_demo_JNIDemo*/
#ifndef_Included_com_ndk_demo_JNIDemo
#define_Included_com_ndk_demo_JNIDemo
#ifdef__cplusplus
extern"C"{
#endif
/*
*Class:
com_ndk_demo_JNIDemo
*Method:
getCint
*Signature:
()I
*/
JNIEXPORTjintJNICALLJava_com_ndk_demo_JNIDemo_getCint
(JNIEnv*,jobject);
/*
*Class:
com_ndk_demo_JNIDemo
*Method:
getCString
*Signature:
()Ljava/lang/String;
*/
JNIEXPORTjstringJNICALLJava_com_ndk_demo_JNIDemo_getCString
(JNIEnv*,jobject);
#ifdef__cplusplus
}
#endif
#endif
大家可以看到在这个头文件中定义的2个借口有什么特点,这2个借口只是提供了定义,并没有实现,而实现的部分,需要手动写c语言文件,当然也可以是c++文件。
编写c++文件和c语言文件可以使用纯文本编辑器也可以使用IDE入VC++6.0,这个无所谓,注意java类型和c的基本类型的映射可参见jni.h文件,返回值类型,必须按照jni.h定义来定义,如果安装了,cygwin你可以在安装目录下找到jni.h文件。
C语言的接口实现:
#include
#include
#include"com_ndk_demo_JNIDemo.h"//注意这里表示该头文件在一个目录下面
inttest(){
intx,y;
x=1;
y=2;
returnx+y;
}
//接口1的实现
JNIEXPORTjintJNICALLJava_com_ndk_demo_JNIDemo_getCint(JNIEnv*env,jobjectthiz)
{
returntest();
}
//接口2的实现
JNIEXPORTjstringJNICALLJava_com_ndk_demo_JNIDemo_getCString(JNIEnv*env,jobjectthiz)
{
(*env)->NewStringUTF(env,"Helll58NDK");
}
3、在ndk项目里建立工程目录
3.1、在apps目录下面建立单个项目目录,如我们在apps目录下建立,demowuba的项目文件件。
3.2、建立Application.mk文件。
3.3、建立project_path目录,通常情况下,名字为project。
3.4、在project目录下建立jni目录,里面放入c文件和头文件另外还有一个Android.mk文件。
4、脚本文件的内容
4.1、Android.mk文件的内容
LOCAL_PATH:
=$(callmy-dir)
include$(CLEAR_VARS)
LOCAL_MODULE:
=demowuba
LOCAL_SRC_FILES:
=com_ndk_demo_JNIDemo.c
include$(BUILD_SHARED_LIBRARY)
4.1.1、LOCAL_PATH:
=$(callmy-dir):
表示此时位于工程的根目录,(callmy-dir)的功能由编译器提供,被用来返回当前目录的地址,包括Android.mk本身。
4.1.2、include$(CLEAR_VARS):
这个变量由编译系统提供,并且指明了一个gnu的make文件,这个功能会清理掉所有以local开头的内容如,local_model,local_stc_files,除了localPath,这句话时必须的,因为如果所有变量都是全局的,所有可控的编译文件都在一个单独的gnu中北解析出来。
4.1.3、LOCAL_MODULE:
=demowuba
这个是必须定义的用来区分android中的每一个模块。
文件名必须是唯一的,不能有空格。
注意这里的编译器会自动为你加上一些前缀。
其实这里就是指定生成.so文件的文件名的,在我的系统中会生成libdemowuba.so其中lib是前缀,demowuba是真正的引用包的文件名,load的时候也是用这个文件名.
4.1.4Local_SRC_FILES
指定源文件,并不需要指定头文件,编译系统会自动查找
4.1.5include$(BUILD_SHARED_LIBRARY)
这个是由系统提供的指定gnumake的脚本,它可以收集到你定义的include$(CLEAR_VARS)以LOCAL开头的变量,并决定哪些需要编译。
4.1.6其他的变量参数,必须可以指定目标平台,硬件类型,参数列表等等,我们一般不关心这些内容,大家感兴趣可以自己研究一下.
4.2Application.mk文件内容
Application.mk用来描述应用程序中的原生模块(这里指的是静态库和动态链接库),每一个Application文件都应该放在ndk的根目录下,作为编译系统的一部分,Application文件必须要有以下参数配置.
APP_PROJECT_PATH:
=$(callmy-dir)/project
APP_MODULES:
=demowuba
注意这里的model名字必须与android.mk名字相同,第一个参数是指的工程目录。
除了这些参数,还有别的,但是一般都用不着,暂时不说了。
4.3编译和使用.so包
使用make命令编译:
编译命令如下:
makeAPP=demowuba-B
编译完成后,会在project\libs\armeabi,生成so包,你可以找到相关的.so文件
使用方法,见demo