android.mk

[http://wenku.baidu.com/view/7759e77ba26925c52cc5bfe9.html]

最近在研究Android 2.3.3源代码的C/C++层,需要对代码进行一些调试,但是奇怪的是,直接添加LOGD("XXXXXXXX");,使用logcat却看不到任何输出,换成LOGI、LOGV、LOGW、LOGE也没有效果。于是在网上查找解决方法,经过几次试验,终于找到了,现在贴到下面备忘:




第一步:在对应的mk文件中加入:LOCAL_LDLIBS := -llog


第二步:在要使用LOG的cpp文件中加入:


#include <android/log.h>


#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "keymatch", __VA_ARGS__)


第三步:这样就可以使用了:LOGD("我要看到的调试信息^_^");


 


这样,在logcat端看到的输出是:


D/keymatch( 32):我要看到的调试信息^_^


 


如果想改变输出中的各项内容,可以参考相应颜色的标示,比如,如果想定义LOGE,就可以把上面的ANDROID_LOG_DEBUG改成ANDROID_LOG_ERROR,同理,LOGI神马的也都以此类推:


#define LOGV(...) __android_log_print(ANDROID_LOG_VERBOSE, "ProjectName", __VA_ARGS__) 


#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG , "ProjectName", __VA_ARGS__)


#define LOGI(...) __android_log_print(ANDROID_LOG_INFO  , "ProjectName", __VA_ARGS__)


#define LOGW(...) __android_log_print(ANDROID_LOG_WARN  , "ProjectName", __VA_ARGS__)


#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR  , "ProjectName", __VA_ARGS__)


 


当然,如果不嫌麻烦,也可以直接使用__android_log_print函数,而不define定义LOGxxx


 


如果还想了解更详细的内容,也可以参考这篇文章: 《在android 输出log 信息 用于调试》


 


另外,有文章称此方法在编译动态库的时候可能会出问题,会提示cannot find -llog的错误。意思是找不到liblog.so这个库文件。


因此需要改成 LOCAL_LDLIBS:=  -L$(SYSROOT)/usr/lib -llog 才可以正常编译。但是我这边编译动态库的时候,好像不用这样改也行,没发现编译时提示“cannot find -llog”的错误


 


 


Android NDK发布后,java+C的编程方式成为android上性能编程的首选。


但在C中调试困难,因此能使用logcat成为必须的要求。


 


关于在Native代码中使用logcat,网上有很多说法,大部分有所欠缺,有的根本是错的。


 


要使用logcat,首先在代码中要引入 log的头文件。


#include <android/log.h>


 


然后你可以简单的通过


__android_log_write(ANDROID_LOG_ERROR,"Tag","Message"); 方法向logcat输出。


log 级别有很多  :


    ANDROID_LOG_UNKNOWN,


    ANDROID_LOG_DEFAULT,   


    ANDROID_LOG_VERBOSE,


    ANDROID_LOG_DEBUG,


    ANDROID_LOG_INFO,


    ANDROID_LOG_WARN,


    ANDROID_LOG_ERROR,


    ANDROID_LOG_FATAL,


    ANDROID_LOG_SILENT,


 


这样写完以后,如果直接编译,就会报 __android_log_write 方法undefined.


怎么回事呢?关键是在设置编译选项上面。


在Android.mk文件里,可以指定一个LOCAL_LDLIBS的参数。如果不指定,那么编译的时候,只会引入默认的几个重要的lib,比如libc之类的。


如果要用log,那就要把 liblog给引进来。


网上很多的写法是 LOCAL_LDLIBS := -llog ,这在build static lib的时候没什么问题。如果是build shared lib,就会报个 cannot find -llog的错误。意思是找不到liblog.so这个库文件。


因此需要改成 LOCAL_LDLIBS :=  -L$(SYSROOT)/usr/lib -llog 才可以正常编译。


其中-L参数是指定了搜索lib的路径。


下面是一个android.mk的内容的例子:


LOCAL_PATH := $(call my-dir)


include $(CLEAR_VARS)


LOCAL_MODULE    := TestNdkNetwork


LOCAL_SRC_FILES := HttpConnection.cpp


LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog


include $(BUILD_SHARED_LIBRARY)

### Android.mk 文件的使用方法及编译配置 Android.mkAndroid 构建系统中用于描述模块依赖和编译规则的 Makefile 文件。它基于 GNU Make 语法,允许开发者定义模块的源文件、编译参数、依赖关系以及目标平台等信息。Android 构建系统在早期版本中主要依赖 Android.mk 和 build/core 下的定义文件进行模块化构建。 #### 定义模块路径 在 Android.mk 文件中,通常以 `LOCAL_PATH := $(call my-dir)` 开头,用于定义当前模块的路径。`my-dir` 是一个宏,用于获取当前 Android.mk 文件所在的目录。该宏通过 `MAKEFILE_LIST` 变量确定当前 Makefile 的位置,并返回其所在目录路径。这一机制确保模块的源文件路径可以正确解析[^1]。 #### 清除变量 在定义模块之前,通常使用 `include $(CLEAR_VARS)` 来清除所有 LOCAL_* 变量,确保当前模块的定义不会受到之前模块的影响。这是构建系统中定义模块的通用做法。 #### 定义模块属性 模块的基本属性包括: - `LOCAL_MODULE`:定义模块的名称,该名称必须唯一。 - `LOCAL_MODULE_CLASS`:指定模块的类别,如 `ETC`、`SHARED_LIBRARIES` 等。 - `LOCAL_SRC_FILES`:指定模块的源文件路径。 - `LOCAL_MODULE_PATH`:定义模块编译后的输出路径。 - `LOCAL_IS_HOST_MODULE`:指定模块是否为宿主机模块。 以下是一个定义预编译配置文件的 Android.mk 示例: ```makefile LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := config LOCAL_MODULE_CLASS := ETC LOCAL_MODULE_PATH := $(HOST_OUT)/etc/kernel_config LOCAL_SRC_FILES := $(TARGET_PREBUILT_TAG)/config LOCAL_IS_HOST_MODULE := true include $(BUILD_PREBUILT) ``` 此配置表示构建一个名为 `config` 的预编译配置文件,并将其放置在宿主机输出目录的 `etc/kernel_config` 路径下[^2]。 #### 指定编译目标 Android.mk 文件中通过 `include $(BUILD_XXX)` 来指定模块的构建方式。常见的构建类型包括: - `BUILD_SHARED_LIBRARY`:构建共享库(`.so` 文件)。 - `BUILD_STATIC_LIBRARY`:构建静态库(`.a` 文件)。 - `BUILD_EXECUTABLE`:构建可执行程序。 - `BUILD_PREBUILT`:用于预编译已存在的二进制文件或资源。 #### 支持多架构编译 Android.mk 支持根据目标架构定义不同的源文件。例如,通过 `LOCAL_SRC_FILES` 和 `TARGET_ARCH` 变量可以指定不同架构的源文件。此外,也可以使用 `LOCAL_MULTILIB` 和 `LOCAL_32_BIT_ONLY` 等变量控制模块的构建架构。 例如,以下配置可以根据 `TARGET_PREBUILT_TAG` 选择不同架构的预编译文件: ```makefile LOCAL_SRC_FILES := $(TARGET_PREBUILT_TAG)/config ``` 该方式常用于构建跨架构的预编译模块,确保在不同目标设备上使用正确的二进制文件[^2]。 #### 模块依赖管理 Android.mk 文件通过 `LOCAL_SHARED_LIBRARIES`、`LOCAL_STATIC_LIBRARIES` 和 `LOCAL_REQUIRED_MODULES` 等字段指定模块依赖。例如: ```makefile LOCAL_SHARED_LIBRARIES := liblog libutils ``` 该配置表示当前模块依赖 `liblog` 和 `libutils` 共享库。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值