[jni] 03_Android.mk文件详解

Android 4.0

Android.mk文件详解

1、Android.mk基本元素解释Android.mk
#1、LOCAL_PATH交叉编译器 在编译c代码/c++代码依赖的配置文件 ,linux下 makefile的语法的子集 
#用于获取当前Android.mk的路径  
LOCAL_PATH :$(call my-dir)

#2、$(CLEAR_VARS)变量的初始化操作 特点: 不会重新初始化LOCAL_PATH 的变量
#凡是这种$()都是makefile的函数
include $(CLEAR_VARS)

#3、LOCAL_MODULE模块名,这个名字会在libs\armeabi目录生成libXXX.so文件
#libHello.so 加lib前缀 .so后缀 makefile的语法约定的
#如果指定LOCAL_MODULE:=libHello那么生成的还是libHello.so,在加载so文件时,还是要写Hello,否则会报错
LOCAL_MODULE :=Hello

#4、LOCAL_SRC_FILES要编译的c源程序
LOCAL_SRC_FILES :=Hello.c 
include $(BUILD_SHARED_LIBRARY)

注意:如果出现问题,在cygwin中,使用ndk-build clean,可以清除编译ndk-build编译生成的
2、Android.mk 的含义详解
 
a) LOCAL_PATH:=$(call my-dir)
 
LOCAL_PATH是定义源文件在哪个目录用的.
 
my-dir 是个定义的宏方法, $(call my-dir)就是调用这个叫 my-dir的宏方法,
这个方法返回值就是 Android.mk文件所在的目录
 
b) include $(CLEAR_VARS)
 
CLEAR_BARS 变量是build system里面的一个变量
这个变量指向了所有的类似 LOCAL_XXX的变量,
执行完这一句话, 这个编译系统就把 所有的类似
LOCAL_MODULE,_SRC_FILELOCALS,LOCAL_STATIC_LIBRARIES,...这样的变量都清除掉
但是不会清除掉 LOCAL_PATH
 
c)  LOCAL_MODULE   
LOCAL_MODULE  就是你要生成的库的名字,名字要是唯一的这个.不能有空格.
编译后系统会自动在前面加上lib的头, 比如说我们的Hello 就编译成了libHello.so
 
还有个特点就是如果你起名叫libHello 编译后ndk就不会给你的module名字前加上lib了
 
但是你最后调用的时候 还是调用Hello这个库,而不是libHello
 
d) LOCAL_SRC_FILES = :Hello.c
这个是指定你要编译哪些文件
不需要指定头文件 ,引用哪些依赖, 因为编译器会自动找到这些依赖 自动编译
 
e) include $(BUILD_SHARED_LIBRARY)  BUILD_STATIC_LIBRARY .so
 
编译后生成的库的类型,如果是静态库.a 配置include $(BUILD_STATIC_LIBRARY)
 
f)  别的参数
 
LOCAL_CPP_EXTENSION := cc //指定c++文件的扩展名
LOCAL_MODULE    := ndkfoo
LOCAL_SRC_FILES := ndkfoo.cc
 
LOCAL_LDLIBS += -llog -lvmsagent -lmpnet -lmpxml -lH264Android
//指定需要加载一些别的什么库.