16

根据我的理解,当当前请求完成时,IntentService 将停止。

考虑以下场景,我将每 100 毫秒触发一次对 IntentSerivce 的请求,并且该请求的处理时间为 90 毫秒。

因此,对于我的每个请求 - startSerivce 调用,将调用服务,并且在 90 毫秒后(一旦处理完成),将调用 IntentServicee 的 onDestroy。

我想让这个 IntentServicee 运行直到我说停止。那可能吗?

假设我将在我的服务中执行以下操作

  1. 进行配置
  2. 发送一些请求
  3. 等待回复
  4. 阅读回复
  5. 广播到调用的活动

步骤 1 对于我的所有请求都是常见的,所以我认为我可以在服务最初启动一次时执行它们,然后根据请求在 HandleIntent 中执行 3-6。

4

4 回答 4

51

IntentService实际上是一个非常小的类,它包装了一个处理程序,问题是在处理了一个 Intent 之后它会调用stopSelf().

删除该单行会给您一个 IntentService 需要显式停止:

public abstract class NonStopIntentService extends Service {

    private String mName;
    private volatile Looper mServiceLooper;
    private volatile ServiceHandler mServiceHandler;

    public NonStopIntentService(String name) {
        super();
        mName = name;
    }

    private final class ServiceHandler extends Handler {
        public ServiceHandler(Looper looper) {
            super(looper);
        }

        @Override
        public void handleMessage(Message msg) {
            onHandleIntent((Intent)msg.obj);
            // stopSelf(msg.arg1); <-- Removed
        }
    }

    @Override
    public void onCreate() {
        super.onCreate();
        HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
        thread.start();

        mServiceLooper = thread.getLooper();
        mServiceHandler = new ServiceHandler(mServiceLooper);
    }

    @Override
    public void onStart(Intent intent, int startId) {
        Message msg = mServiceHandler.obtainMessage();
        msg.arg1 = startId;
        msg.obj = intent;
        mServiceHandler.sendMessage(msg);
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        onStart(intent, startId);
        return START_STICKY;
    }    

    @Override
    public void onDestroy() {
        mServiceLooper.quit();
    }

    @Override
    public IBinder onBind(Intent intent) {
        // TODO Auto-generated method stub
        return null;
    }

    /**
     * This method is invoked on the worker thread with a request to process.
     * Only one Intent is processed at a time, but the processing happens on a
     * worker thread that runs independently from other application logic.
     * So, if this code takes a long time, it will hold up other requests to
     * the same IntentService, but it will not hold up anything else.
     *
     * @param intent The value passed to {@link
     *               android.content.Context#startService(Intent)}.
     */
    protected abstract void onHandleIntent(Intent intent);  

}
于 2012-03-30T13:44:49.463 回答
2

IntentService从标准Service类扩展,所以我不明白为什么不应该这样做。事实上,我也会这样做。;)

于 2011-11-05T11:53:19.183 回答
1

如果您在服务中没有太多工作要做,您可以延长常规服务。在 onBind() 中返回 null 并在返回 START_STICKY 的 onStartCommand() 中接收命令。

于 2015-01-25T20:58:33.583 回答
-2

您需要为您的服务创建一个Serviceandbind以防止它停止。请参阅文档

将启动的服务将bindService()一直运行,直到没有 Activity 仍然绑定到它为止。

于 2011-07-27T08:10:47.880 回答