应用程序自启动未正常工作

7
我正在使用一个简单的自动启动应用程序,其中包含TimerTask实现,在几乎所有设备上都可以正常工作。问题在于它在三星Galaxy Y(2.3.6)和DELL XCD35(2.2)中无法工作。当设备启动时,TimerTask会工作一段时间,然后关闭。我在“应用程序->管理应用程序”中检查,发现应用程序已经处于“强制停止”状态。这意味着我的应用程序在几秒钟后会被停止。那么,如果有人有解决方案,请分享一下在这两个设备中出现这种奇怪行为的原因是什么。

以下是我的代码。

MyReceiver.java

public class MyReceiver extends BroadcastReceiver{

    private Timer mTimer = new Timer();
    @Override
    public void onReceive(Context context, Intent arg1) {
        Toast.makeText(context, "Device Booted", Toast.LENGTH_LONG).show();
        Log.d("TAG","Device Booted");
        mTimer.scheduleAtFixedRate(new MyTimerTask(), 2000,2000);
    }

    private class MyTimerTask extends TimerTask
    {
        @Override
        public void run() {
            Log.d("TAG","TimerTask executed....");
        }
    }
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.autostart.app"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="8" />
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <receiver android:name=".MyReceiver">
            <intent-filter>
                <action android:name="android.intent.action.BOOT_COMPLETED"/>
            </intent-filter>
        </receiver>
    </application>
</manifest>

啊!!!为什么会被投反对票? - Lalit Poptani
3
一个有效的、格式良好的问题,不需要被投票下降... - WarrenFaith
2个回答

2

我建议你使用AlarmManager而不是TimerTask,因为我在许多设备上都遇到了你描述的同样的问题。

    public void onReceive(Context context, Intent arg1) {
    Toast.makeText(context, "Device Booted", Toast.LENGTH_LONG).show();
    Log.d("TAG","Device Booted");
AlarmManager AM =(AlarmManager)getSystemService(Context.ALARM_SERVICE);
    Intent intent = new Intent();
    intent.setAction("ALARM_MANAGER_ACTION");//can add any string action here
    PendingIntent pi = PendingIntent.getBroadcast(mContext
                                        .getApplicationContext(), 0, intent,0);
AM.set(AlarmManager.RTC,selectedTime, pi);
AM.setRepeating(AM.RTC_WAKEUP, System.currentTimeMillis()+2000, 2000, pi);
    }


  public class MyReceiver1 extends BroadcastReceiver{ 
  //event will come here
  private Timer mTimer = new Timer();
  @Override
  public void onReceive(Context context, Intent arg1) {
 // check if event is same as you broadcasted through alarmManager
    Toast.makeText(context, "Device Booted", Toast.LENGTH_LONG).show();
     Log.d("TAG","TimerTask executed....");

}

在您的应用程序中添加一个广播接收器,它应该监听 ("ALARM_MANAGER_ACTION") 动作,并将此动作添加到清单文件中。 我敢打赌这个方法也可以在这两个设备上工作。


0

我认为在一些 Android OS 中,有时操作系统会在设备启动时杀死正在运行的线程,而这些线程是 Android 不熟悉或无法识别的。这就是为什么 TimerTask 在某些设备上工作,在某些设备上只能工作 5-10 秒钟,然后应用程序会被 Android 操作系统在设备启动时 自动 强制停止注意 - 这是从“管理应用程序”中的“强制停止”,而不是“强制关闭”,因此 Logcat 中没有任何错误)。

因此,在这种情况下,解决方案是使用内置的机制,该机制由 Android OS 认可并且不会将其杀死,并使其处于运行模式。在这种情况下,我使用 AlarmManager 来执行我的任务,并且它可以正常工作。

我可能不是完全正确,但我的最终解决方案是使用 AlarmManager 使我的应用程序在每个设备上都能正常工作。

@Override
    public void onReceive(Context context, Intent arg1) {

        Intent myIntent = new Intent(context, AlarmService.class);
        PendingIntent pendingIntent = PendingIntent.
                                         getService(context, 0, myIntent, 0);
        AlarmManager alarmManager = (AlarmManager) context
                                    .getSystemService(Context.ALARM_SERVICE);
        alarmManager.setRepeating(AlarmManager.RTC_WAKEUP,
                      System.currentTimeMillis() + 2000, 2000, pendingIntent);
    }

更新:

AlaramManager是一项关键的系统服务,它始终运行。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接