Android開發實踐:Android交叉編譯工具鏈的使用

前面2篇文章分別介紹了Android NDK編譯的命令行參數,以及如何在任意目錄使用Android.mk來編譯本地c/c++代碼,Andriod.mk和ndk-build只不過是Android官方提供了一套封裝過的Android交叉編譯環境而已,其實,你能夠不用它,而直接經過傳統的Makefile文件來編譯你的c/c++代碼的,本文即介紹如何直接經過傳統的Makefile文件來編譯可用於Android平臺的庫文件linux


常常搞嵌入式開發的朋友對於交叉編譯環境應該並不陌生,說白了,就是一組運行在x86 PC機的編譯工具,可讓你在PC機上編譯出目標平臺(例如ARM)可識別的二進制文件。Android平臺也提供了這樣的交叉編譯工具鏈,就放在Android的NDK開發包的toolchains目錄下,所以,咱們的Makefile文件中,只需給出相應的編譯工具便可。android


廢話就先說到這,直接上例子,咱們目標是把下面這個math.c文件編譯成一個靜態庫文件c++


#include <stdio.h>

int add( int a , int b ) {
    return a+b;
}


你須要編寫一個Makefile文件,這裏假設你的Android ndk被安裝在 /opt/android/ndk 目錄下,固然,你能夠根據本身的實際狀況修改Makefile中相關路徑的定義,Makefile文件示例以下ide


# Makefile Written by ticktick
# Show how to cross-compile c/c++ code for android platform

.PHONY: clean

NDKROOT=/opt/android/ndk
PLATFORM=$(NDKROOT)/platforms/android-14/arch-arm

CROSS_COMPILE=$(NDKROOT)/toolchains/arm-linux-androideabi-4.6/prebuilt/linux-x86/bin/arm-linux-androideabi-

CC=$(CROSS_COMPILE)gcc
AR=$(CROSS_COMPILE)ar
LD=$(CROSS_COMPILE)ld

CFLAGS = -I$(PWD) -I$(PLATFORM)/usr/include -Wall -O2 -fPIC -DANDROID -DHAVE_PTHREAD -mfpu=neon -mfloat-abi=softfp
LDFLAGS =

TARGET = libmath.a
SRCS = $(wildcard *.c)
OBJS = $(SRCS:.c=.o)

all: $(OBJS)
        $(AR) -rc $(TARGET) $(OBJS)
clean:
        rm -f *.o *.a *.so

這裏不講Makefile文件的基本原理,只說明一下針對Android環境的Makefile文件編寫的注意事項。工具


(1) CROSS_COMPILEui


必須正確給出Android NDK編譯工具鏈的路徑,當在目錄中執行make命令的時候,編譯系統會根據 CROSS_COMPILE 前綴尋找對應的編譯命令。idea


(2) -I$(PLATFORM)/usr/includespa


因爲Android平臺沒有使用傳統的c語言庫libc,而是本身編寫了一套更加高效更適合嵌入式平臺的c語言庫,因此係統頭文件目錄不能再使用默認的路徑,必須直到Android平臺的頭文件目錄命令行


(3) -Wall -O2 -fPIC -DANDROID -DHAVE_PTHREAD -mfpu=neon -mfloat-abi=softfpcode


這些參數的意義網上基本上都有介紹,我就不一一解釋了,並不都是必須添加的,但比較經常使用。


編譯方法:


寫好makefile文件,而且保存以後,就能夠直接在當前目錄下執行make命令,編譯完成後,當前目錄下會生成 libmath.a ,便可直接拿到Android的jni工程中和使用了。


關於如何直接使用Makefile文件交叉編譯Android平臺的c/c++代碼就介紹到這裏了,有任何疑問歡迎留言或者來信lujun.hust@gmail.com交流,或者關注個人新浪微博 @盧_俊 獲取最新的文章和資訊。

相關文章
相關標籤/搜索