Android中C语言打log

/********************** log.c *************************/
#include <jni.h>
#include <utils/Log.h>
int main()
{
    LOGD("调试信息!!!!!!!!!!\n");
    return 0;
}


/********************** Android.mk *************************/
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)

LOCAL_SRC_FILES:= \
    log.c

LOCAL_SHARED_LIBRARIES := \
    libutils \

#如果没有下面这一行,将提示jni.h找不到(error: jni.h: No such file or directory)
LOCAL_C_INCLUDES := \
    $(JNI_H_INCLUDE)


LOCAL_PRELINK_MODULE := false

LOCAL_MODULE:=optional    #如果没有这一句编译可能不通过(转载者注)

LOCAL_MODULE:= syslog_test
include $(BUILD_EXECUTABLE)

===========================
然后编译运行,使用logcat就可以看到我们写的那行信息。

D/        ( 191): 调试信息!!!!!!!!!!



4月1日补充:
用C语言并不是只有LOGD一种方式可以将信息写入日志,查阅android源码/system/core/include/cutils/log.h中的代码后得知,还有其他几种基本的宏,如LOGE、LOGV、LOGI、LOGW等,它们的使用场合是有差别的,关于这点,源码中是这样注释的。

LOGV:Simplified macro to send a verbose log message using the current LOG_TAG
LOGD:Simplified macro to send a debug log message using the current LOG_TAG.
LOGI:Simplified macro to send an info log message using the current LOG_TAG.
LOGW:Simplified macro to send a warning log message using the current LOG_TAG.
LOGE:Simplified macro to send an error log message using the current LOG_TAG.


可见,LOG后面的字母就是它们输出信息种类的单词的首字母。

关于这几个宏的详细使用场合可参看这篇文章(
《Google Android中打印日志》 )。里面介绍的比较详细,是用java语言举的例子。如果想在C语言程序中调用这几个宏,可以参考本文中的例子。

对昨天写的log.c作如下修改,将5个宏都添加进去。

/********************** log.c *************************/
#include <jni.h>
#include <utils/Log.h>
int main()
{
    LOGD("调试!!!!!!!!!!\n");
    LOGE("出错!!!!!!!!!!\n");
    LOGV("详述!!!!!!!!!!\n");
    LOGI("消息!!!!!!!!!!\n");
    LOGW("警告!!!!!!!!!!\n");
    return 0;
}

编译运行后,有一个比较奇怪的现象,就是LOGV没有输出到logcat,其他四个都有输出,这个还没弄明白是为什么。

// 程序运行结果(使用logcat查看)
D/        ( 193): 调试!!!!!!!!!!
E/        ( 193): 出错!!!!!!!!!!
I/        ( 193): 消息!!!!!!!!!!
W/        ( 193): 警告!!!!!!!!!!

从logcat的每条信息前面的字母也可以看出,D、E、I、W分别对应的是调试、出错、消息、警告。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Android Studio 使用 C 语言来收发短信,需要使用 Android NDK (Native Development Kit) 和 Android SMS Manager API。 以下是一个简单的示例代码,可以使用 C 语言来发送短信: ``` #include <jni.h> #include <android/log.h> #include <stdlib.h> #include <string.h> jstring Java_com_example_smsapp_MainActivity_sendSMS(JNIEnv* env, jobject obj, jstring phoneNumber, jstring message) { jclass smsManagerClass = (*env)->FindClass(env, "android/telephony/SmsManager"); jmethodID getDefaultMethod = (*env)->GetStaticMethodID(env, smsManagerClass, "getDefault", "()Landroid/telephony/SmsManager;"); jobject smsManager = (*env)->CallStaticObjectMethod(env, smsManagerClass, getDefaultMethod); const char* phoneNumberCStr = (*env)->GetStringUTFChars(env, phoneNumber, NULL); jstring destinationAddress = (*env)->NewStringUTF(env, phoneNumberCStr); const char* messageCStr = (*env)->GetStringUTFChars(env, message, NULL); jstring text = (*env)->NewStringUTF(env, messageCStr); jmethodID sendTextMessageMethod = (*env)->GetMethodID(env, smsManagerClass, "sendTextMessage", "(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Landroid/app/PendingIntent;Landroid/app/PendingIntent;)V"); (*env)->CallVoidMethod(env, smsManager, sendTextMessageMethod, destinationAddress, NULL, text, NULL, NULL); (*env)->ReleaseStringUTFChars(env, phoneNumber, phoneNumberCStr); (*env)->ReleaseStringUTFChars(env, message, messageCStr); return (*env)->NewStringUTF(env, "SMS sent successfully!"); } ``` 在此示例代码,`sendSMS` 函数是一个 JNI (Java Native Interface) 函数,可以从 Java 代码调用。在此函数,我们首先获取 `SmsManager` 的实例,然后将目标电话号码和消息转换为 C 字符串并创建相应的 Java 字符串对象。最后,我们调用 `sendTextMessage` 方法来发送短信。 在 Android Studio 使用 NDK 编译此代码时,需要编写一个 CMake 或 ndk-build 脚本来指定编译器、链接库等设置。可以参考 Android NDK 文档来了解更多信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值