我确信我一定是错过了一些明显的东西,但这目前让我感到困惑。
我有一个扩展 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/