Jee*_*tel 42 c java-native-interface logging android android-ndk
如果我在java文件中定义这样的功能
/**
* Adds two integers, returning their sum
*/
public native int add( int v1, int v2 );
Run Code Online (Sandbox Code Playgroud)
所以我需要在c文件中编码
JNIEXPORT jint JNICALL Java_com_marakana_NativeLib_add
(JNIEnv * env, jobject obj, jint value1, jint value2) {
printf("\n this is log messge \n");
return (value1 + value2);
}
Run Code Online (Sandbox Code Playgroud)
然后从这个printf将打印它的消息?在logcate我不明白吗?
如何通过放置日志消息来调试任何NDK应用程序?
Sha*_*ful 99
使用__android_log_print()来代替.你必须包括标题<android/log.h>
示例示例. __android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "\n this is log messge \n");
您还可以使用printf等格式说明符 -
__android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "Need to print : %d %s",int_var, str_var);
Run Code Online (Sandbox Code Playgroud)
确保您还链接到Android.mk文件中的日志库:
LOCAL_LDLIBS := -llog
Run Code Online (Sandbox Code Playgroud)
哦..忘了..输出将显示Logcat带标签LOG_TAG
简单方法
将以下行添加到公共头文件中.
#include <android/log.h>
#define LOG_TAG "your-log-tag"
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)
// If you want you can add other log definition for info, warning etc
Run Code Online (Sandbox Code Playgroud)
现在就像打电话LOGD("Hello world") or LOGE("Number = %d", any_int)一样printf in c.
不要忘记包含公共头文件.
删除日志记录
如果您定义为LOGD(...)空,则所有日志都将消失.只需评论一下LOGD(...).
#define LOGD(...) // __android_log..... rest of the code
Mār*_*iko 16
有两种选择:
1)用__android_log_print替换printf.您可以在代码开头定义时轻松完成此操作:
#define printf(...) __android_log_print(ANDROID_LOG_DEBUG, "TAG", __VA_ARGS__);
Run Code Online (Sandbox Code Playgroud)
当然,这将需要更改具有printf的所有源代码.
2)将stdout和stderr重定向到Android logcat(不确定这是否适用于非root设备):http://developer.android.com/guide/developing/debugging/debugging-log.html#viewingStd
小智 5
不需要root设备,可以访问http://developer.android.com/guide/developing/debugging/debugging-log.html#viewingStd,下面可以完美地工作.
$ adb shell
$ su
$ stop
$ setprop log.redirect-stdio true
$ start
Run Code Online (Sandbox Code Playgroud)
完成了!
| 归档时间: |
|
| 查看次数: |
59393 次 |
| 最近记录: |