Android.mk添加本地程序和庫的經常使用模版
Android中添加本地程序或者庫。這些程序和庫與其所在路徑沒有關係。僅僅與它們的配置文件Android.mk有關。Android.mk文件裏可以主要包括一些系統公共的宏。在一個Android.mk中可以生成多個可運行程序、動態庫或者靜態庫。
A,編譯C/C++應用程序的模板
#Demo Exe
LOCAL_PATH := $(call my-dir)
#include $(CLEAR_VARS)
LOCAL_SRC_FILES:= main.c
LOCAL_MODULE:= Demo_exe
#LOCAL_C_INCLUDES :=
#LOCAL_STATIC_LIBRARIES :=
#LOCAL_SHARED_LIBRARIES :=
include $(BUILD_EXECUTABLE)
(解釋::=是賦值的意思,+=是追加的意思,$是引用某變量的值)BUILD_EXECUTABLE表示以一個可運行程序的方式進行編譯。
補充說明:
include$(BUILD_PACKAGE) 則是編譯出一個apk,
include$(BUILD_STATIC_JAVA_LIBRARY)則是編譯出jar包。
B。編譯靜態庫的模板
#Demo Static Lib
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_SRC_FILES:= /
helloworld.c
LOCAL_MODULE:= libdemo_static
#LOCAL_C_INCLUDES :=
#LOCAL_STATIC_LIBRARIES :=
#LOCAL_SHARED_LIBRARIES :=
include $(BUILD_STATIC_LIBRARY)
一般的和上面相似,BUILD_STATIC_LIBRARY表示編譯一個靜態庫.a文件。
靜態庫不會拷貝到的APK包中,可是可以用於編譯共享庫。
C,編譯動態庫的模板
#Demo Shared Lib
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_SRC_FILES:= /
helloworld.c
LOCAL_MODULE:= libdemo_shared
TARGET_PRELINK_MODULES := false
#LOCAL_C_INCLUDES :=
#LOCAL_STATIC_LIBRARIES :=
#LOCAL_SHARED_LIBRARIES :=
include$(BUILD_SHARED_LIBRARY)
一般的和上面相似,BUILD_SHARED_LIBRARY表示編譯一個動態庫。
以上三者的生成結果分別在例如以下,generic依詳細target會變:
out/target/product/generic/obj/EXECUTABLE
out/target/product/generic/obj/STATIC_LIBRARY
out/target/product/generic/obj/SHARED_LIBRARY
每一個模塊的目標目錄分別爲:
可運行程序:XXX_intermediates
靜態庫: XXX_static_intermediates
動態庫: XXX_shared_intermediates
在Android.mk文件裏,還能夠指定最後的目標安裝路徑,用LOCAL_MODULE_PATH和LOCAL_UNSTRIPPED_PATH來指定。不同的文件系統路徑用下面的宏進行選擇:
TARGET_ROOT_OUT:表示根文件系統out/target/product/generic/root。
TARGET_OUT:表示system文件系統out/target/product/generic/system。
TARGET_OUT_DATA:表示data文件系統out/target/product/generic/data。 OUT_DIR:代碼project編譯時的out生成文件夾 PRODUCT_OUT:映象生成文件夾
使用方法示比例如以下:
LOCAL_MODULE_PATH :=$(TARGET_ROOT_OUT)