Android Log.d ("SMS", str) 消息在操作中丢失

标签 android logging sms

我确信我一定是错过了一些明显的东西,但这目前让我感到困惑。

我有一个扩展 BroadcastReceiver 的类,该类被设置为 list 中的接收器,并且它确实正确捕获了短信接收 Intent 。

package gull.sana.textit;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.SmsMessage;
import android.util.Log;
import android.widget.Toast;

public class SMSReceiver extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {
        Log.d("SMSReceiver", "Intent received");
        //---get the SMS message passed in---
        Bundle bundle = intent.getExtras();        
        SmsMessage[] msgs = null;
        String str = "";            
        if (bundle != null)
        {
            //---retrieve the SMS message received---
            Object[] pdus = (Object[]) bundle.get("pdus");
            msgs = new SmsMessage[pdus.length];            
            for (int i=0; i<msgs.length; i++){
                msgs[i] = SmsMessage.createFromPdu((byte[])pdus[i]);                
                str += "SMS from " + msgs[i].getOriginatingAddress();                     
                str += " :";
                str += msgs[i].getMessageBody().toString();
                str += "\n";        
            }
            Log.d("SMS", str);
            //---display the new SMS message---
            Toast.makeText(context, str, Toast.LENGTH_SHORT).show();

        }
    }
}

现在,当我发送短信时,我总是收到第一条日志消息 Log.d("SMSReceiver", "Intent received");我总是得到 Toast 正如我所期望的,但是,我从来没有得到 Log.d("SMS", str);

我做错了什么吗?为什么Toast出现了,而之前的日志却没有出现?

最佳答案

事实证明,有多个日志消息缓冲区。标签决定这些日志进入哪个缓冲区。据此https://stackoverflow.com/a/9011945/1475461 SMS 是放入不同缓冲区的标签之一。

可以使用以下命令查看其他缓冲区

adb logcat -b radio

感谢@nKn 让我走上正确的道路。

关于Android Log.d ("SMS", str) 消息在操作中丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22081657/

相关文章:

iphone - OpenGL ES : getting a fixed size for an object

Android Facebook Sdk 4.11.0 如何在没有任何链接或图像的情况下将简单的状态更新发布到墙上

tomcat - 尽管有 log4j.xml,但 Log4J 在 Tomcat 5.5 上以 DEBUG 级别运行

logging - 如何使用goaccess解析多个日志nginx文件

python - 从 django 应用程序发送短信

batch-file - 如何从批处理脚本发送短信?

java - Android BroadcastReceiver 不会注册

java - largeHeap=true list 标签不起作用?

logging - 我可以在运行时更改 Enterprise Library Logging block 的配置吗?

r - 为什么在 R 中使用 plivo 发送短信失败?