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



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

我有一个扩展 BroadcastReceiver 的类,该类在清单中设置为接收器,并且它确实正确捕获了收到的 sms 意图。

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);

我做错了什么吗?为什么吐司出现了,而之前的日志却从未出现过?

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

可以使用以下命令查看另一个缓冲区

adb logcat -b radio

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

当您将

Log.*与名为 SMS 的标签结合使用时,这似乎是一个古老的已知问题。对此似乎没有逻辑解释,但您的代码正在相应地工作,只是Log.d()行无法正常工作。

您应该将标记SMS替换为其他标记,在这种情况下,它应该按预期工作(在这种情况下,避免错误)。

最新更新