Android 开发手记四(C可执行程序编译实例 .)

 继续 NDK 的开发。上次我们的实例中,对 C 应用程序的编译链接,自己编写的 makefile 是件比较困难的事情。虽然最后成功了,不过中间经历了不少坎坷。我们现在研究下如何用 NDK 提供的 build 工具,实现我们的目标。

 

        还是以 Hello Android 工程为例。
 

        建立好工程 hello-a ,在 jni 目录下创建文件 hello-a.c, 文件内容如下。

#include <stdio.h> 
int main() 

{ 

       printf("Hello Android!/n"); 

       return 0; 

} 
 

 

在该目录下,创建 Android.mk 文件,内容如下:

LOCAL_PATH := $(call my-dir) 

include $(CLEAR_VARS) 

LOCAL_MODULE    := helloa 

LOCAL_SRC_FILES := hello-a.c 

include $(BUILD_EXECUTABLE) 
 

 

这里需要注意的上面红色部分,指定我们现在要生成一个可执行的文件。
       在工程下运行 ndk-build ,结果提示错误:

Android 开发手记四(C可执行程序编译实例 .)_第1张图片

 这个提示告诉我们,在工程中没有找到 AndroidManifest.xml 文件。若创建了 Java 应用程序,会自动生成该文件。在该文件中, 描述了程序包的一个全局变量 , 包括暴露的应用组件 (activities, services 等等 ) 和为每个组件的实现类 , 什么样的数据可以操作 , 以及在什么地方运行。而这里,我们根本不需要这个文件。那么为什么会有这样的错误提示呢?

       其实这个和 NDK 的版本有关系。现在最新的版本,就是我用的版本 NDK r4 版,与之前的版本,一个很大的改变,就是对工程源文件路径及组织结构的变化。在 NDK r3 版,按装 NDK 后,需要运行 setup.sh 来创建编译环境,需要在 <NDK>APPS/ 目录下,创建同名的工程,然后添加 Application.mk, 然后编译的时候,执行 make APP=yourproject 。 新的版本不需要再去创建这个同名的 app 工程,直接用编译工具 ndk-build 就可以了。这个工具实际上是对 build 编译工具的一层封装,每次编译都会自动去设置一次编译环境,然后调用工程中的 Android.mk 来进行工程的编译,原来的那个 Application.mk 也不是必须的了,只有在需要的时候,才去创建。不过相比前一版本,就是增加了对 AndroidManifest.xml 文件的检查。

       我们如何解决这个问题呢?有两个办法:一是手动创建一个 AndroidManifest.xml 文件,然后里面内容为空项就行,如

<?xml version="1.0" encoding="utf-8"?> 

<manifest/> 
 

      我们再次运行 ndk-build ,成功。

 

 我们试试可否正常运行:

Android 开发手记四(C可执行程序编译实例 .)_第2张图片

 看到了 Hello Android! 成功了。
       这种方法虽然解决了问题,但是并没有理解问题的实质。好,保持求知的强劲势头和欲望,这就有了第二种解决办法。
       我们先来看看开发者对这个问题的描述:
“The manifest is only required to find the top-level of your project path (ndk-build can be invoked in any sub-directory of your project).”

       那么,我们只要在编译前指定工程路径就行了,如何做呢?简单!
       ndk-build NDK_PROJECT_PATH=/path/to/project

       好,我们试试看

成功了,看看在模拟器上的运行效果:

Android 开发手记四(C可执行程序编译实例 .)_第3张图片

摘自:http://blog.csdn.net/l____j/article/details/5787746

你可能感兴趣的:(android,开发)