我使用的是JellyBean,而不是KitKat或更高版本的API,因此应在正确的时间调用onReceive方法。
问题出在大多数情况下,我的电话都被唤醒,但有时却没有(我看保存日志的时间)。

这就是我创建待定意图的方法:

    PendingIntent pendingIntent;
    AlarmManager manager;

    Intent alarmIntent = new Intent(this, AlarmReceiver.class);

    pendingIntent = PendingIntent.getBroadcast(this, idSms, alarmIntent, 0);

    manager.set(AlarmManager.RTC_WAKEUP, time, pendingIntent);


现在BroadcastReceiver

public class AlarmReceiver extends BroadcastReceiver {

    private static final String TAG = "AlarmReceiver";

    @Override
    public void onReceive(Context arg0, Intent arg1) {
        Log.d(TAG, "onReceive()");
    }
}


就是这样了。 BroadcastReceiver是在清单中声明的​​,就像我在大多数时间之前写的那样,但是有时我不得不自己打开手机以查看日志...
我读了几个主题,却没有找到答案为什么会发生。
我也了解WakeLocker,我尝试在日志后执行该操作,但是我认为onReceive甚至没有被调用,至少日志有时没有显示。

希望提供一些建议或解释为什么它一直都不起作用。
谢谢

编辑1:我添加了一些代码,当手机处于休眠状态时仍然无法使用:

public void onReceive(Context arg0, Intent arg1) {
PowerManager pm = (PowerManager) arg0.getSystemService(Context.POWER_SERVICE);
PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "WakeLock");
wl.acquire();
Log.d(TAG, "onReceive()");
wl.release();
}


编辑2:更改代码:

public class AlarmReceiver extends WakefulBroadcastReceiver {

    private static final String TAG = "AlarmWakefulReceiver";

    @Override
    public void onReceive(Context arg0, Intent arg1) {
        Log.d(TAG, "onReceive()");
        Intent service = new Intent(arg0, SmsService.class);
        Log.d(TAG, "Creating service");
        startWakefulService(arg0, service);
    }
}


public class SmsService extends IntentService {
    private static final String TAG = "IntentService";

    public SmsService() {
        super("SmsService");
    }

    @Override
    protected void onHandleIntent(Intent intent) {
        Toast.makeText(this, "Service completed", Toast.LENGTH_SHORT).show();
        Log.i(TAG, "Completed service");
        AlarmReceiver.completeWakefulIntent(intent);
    }

}


服务已注册并正常工作,我将时间设置为8:47,将电话设置为8:49,并在该时间获取onReceive()。日志:

01-15 08:49:04.894: D/AlarmWakefulReceiver(32576): onReceive()
01-15 08:49:04.894: D/AlarmWakefulReceiver(32576): Creating service
01-15 08:49:04.914: I/IntentService(32576): Completed service


编辑3:
我在手机上对此进行了测试:http://wptrafficanalyzer.in/blog/setting-up-alarm-using-alarmmanager-and-waking-up-screen-and-unlocking-keypad-on-alarm-goes-off-in-android/

我的手机是Xperia L,系统4.2.2

最佳答案

http://commonsware.com/blog/2013/03/08/warning-xperia-z-stamina-alarmmanager.html

我有Xperia L并检查了此链接...好吧...我的Xperia具有耐力模式。似乎Stamina有时会阻止我的唤醒功能。

为了解决这个问题,您需要进入电源管理选项,进入耐力模式并将其关闭或将我们的应用程序设置为例外。到目前为止效果很好,我将进行更多测试,并确定是否存在问题!

编辑1:

10:04-我将警报设置为10:21触发,并在10:28检查了效果,可以了!

日志:

01-15 10:21:16.804: D/AlarmWakefulReceiver(11202): onReceive()
01-15 10:21:16.814: D/AlarmWakefulReceiver(11202): Creating service
01-15 10:21:16.834: I/IntentService(11202): Completed service

10-08 16:25