我确信我一定只是错过了一些明显的东西,但这目前让我感到困惑。
我有一个扩展 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
替换为其他标记,在这种情况下,它应该按预期工作(在这种情况下,避免错误)。