WEB开发网
开发学院手机开发Android 开发 Android.mk 文件语法规范 阅读

Android.mk 文件语法规范

 2010-07-20 13:26:00 来源:WEB开发网   
核心提示:LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES, 等等...),除LOCAL_PATH ,Android.mk 文件语法规范(2),这是必要的,因为所有的编译控制文件都在同一个GNU MAKE执行环境中,但是NDK编译系统保留下列变量名:-以LOCAL_开头的名字(例如 LOCAL_MO
LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES, 等等...),除LOCAL_PATH 。这是必要的,因为所有的编译控制文件都在同一个GNU MAKE执行环境中,所有的变量都是全局的。

LOCAL_MODULE := helloworld

LOCAL_MODULE变量必须定义,以标识你在 Android.mk文件中描述的每个模块。名称必须是唯一的,而且不包含任何空格。注意编译系统会自动产生合适的前缀和后缀,换句话说,一个被命名为'foo'的共享库模块,将会生成'libfoo.so'文件。

重要注意事项:如果你把库命名为‘libhelloworld’,编译系统将不会添加任何的lib前缀,也会生成libhelloworld.so,这是为了支持来源于Android平台的源代码的Android.mk文件,如果你确实需要这么做的话。

LOCAL_SRC_FILES := helloworld.c

LOCAL_SRC_FILES变量必须包含将要编译打包进模块中的C或C++源代码文件。注意,你不用在这里列出头文件和包含文件,因为编译系统将会自动为你找出依赖型的文件;仅仅列出直接传递给编译器的源代码文件就好。【注意,默认的C++源码文件的扩展名是’.cpp’. 指定一个不同的扩展名也是可能的,只要定义LOCAL_DEFAULT_CPP_EXTENSION变量,不要忘记开始的小圆点(也就是定义为 ‘.cxx’,而不是‘cxx’)(当然这一步我们一般不会去改它)】

include $(BUILD_SHARED_LIBRARY)

BUILD_SHARED_LIBRARY是编译系统提供的变量,指向一个GNU Makefile脚本(应该就是在build/core 目录下的shared_library.mk),负责收集自从上次调用'include $(CLEAR_VARS)'以来,定义在LOCAL_XXX变量中的所有信息,并且决定编译什么,如何正确地去做。并根据其规则生成静态库。同理对于静态库。

在sources/samples目录下有更复杂一点的例子,写有注释的Android.mk文件,你可以看看。

二、参考

这是一份你应该在Android.mk中依赖或定义的变量列表,您可以定义其他变量为自己使用,但是NDK编译系统保留下列变量名:

-以LOCAL_开头的名字(例如 LOCAL_MODULE)

-以PRIVATE_, NDK_ or APP_开头的名字(内部使用)

-小写名字(内部使用,例如’my-dir’)

如果您为了方便在Android.mk中定义自己的变量,我们建议使用MY_前缀,一个小例子:

MY_SOURCES := foo.c

ifneq ($(MY_CONFIG_BAR),)

MY_SOURCES += bar.c

上一页  1 2 3 4 5 6 7  下一页

Tags:Android mk 文件

编辑录入:coldstar [复制链接] [打 印]
赞助商链接