首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 移动开发 > 移动开发 >

NDK使用log的有关问题

2012-11-23 
NDK使用log的问题NDK使用log的问题在编译so文件的c或cpp文件之前中加入以下代码,就可以在android中的log显

NDK使用log的问题

NDK使用log的问题

在编译so文件的c或cpp文件之前中加入以下代码,就可以在android中的log显示日志内容

#include <android/log.h>

logcat的级别:

??? 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(ANDROID_LOG_WARN,”biqian”,”neirong”)

2.如果要用log,那就要把 liblog给引进来。Android.mk中加LOCAL_LDLIBS := -llog

3.如果不加第二步,直接编译,就会报 __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)

热点排行