如果要在Service中进行耗时任务,就需要用到IntentService。因为普通的Service有两个问题:
1.Service不会专门启动一条单独的进程,Service与它所在应用位于同一个进程中。
2.Service也不是专门一条新的线程,因此不应该在Service中直接处理耗时任务。
这里说一下在BindService中启动线程处理耗时任务是不靠谱的,因为Activity可能会被用户直接退出,BroadcastReceiver的生命周期本身就很短。可能出现的情况就是:在子线程还没结束的情况下,Activity已经被用户退出,或者BroadcastReceiver已经结束,在两者都已近退出的情况下,此时它们所在的进程就变成空进程(没有任何活动组件进程),系统需要内存时可能会优先终止进程。如果宿主进程被终止,那么该进程内的所有子线程也会被终止,这样就会导致子线程无法完成任务。
下面说下IntentService的原理:IntentService使用队列来管理请求Intent,每当用户端代码通过Intent请求启动IntentService时,IntentService会将该Intent加入列队,然后开启一条新的worker线程来处理这个Intent。对于异步的startServce请求,intentService会按次序来处理列队的Intent,这个线程保证同一时刻只处理一个Intent。由于IntentService
使用新的worker线程处理Intent请求,因此intentService不会阻塞主线程,故它可以处理耗时任务。
下面归纳一下它的具体特征:
1.IntentService会创建单独的worker线程来处理所有的Intent请求
2.IntentService会创建单独的worker线程处理onHandleIntent()方法实现代码,因此我么不需要担心多线程问题。
3.当所有请求处理完成后,intentService会自动停止
4.为Service的onBind方法提供默认实现,默认返回null。
5.为Service的onstartcommand()方法提供默认实现,这个实现会将请求Intent添加到队列中。
下面我举一个例子,下面例子我只写了一个intentService,用它来处理耗时任务。Activity只是启动Service就不写了。
注意Service别忘了注册:
public class MyIntentService extends IntentService
{
public MyIntentService()
{
super("MyIntentService");
}
// IntentService会使用单独的线程来执行该方法的代码
@Override
protected void onHandleIntent(Intent intent)
{
// 该方法内可以执行任何耗时任务,比如下载文件等,此处只是让线程暂停20秒
long endTime = System.currentTimeMillis() + 20 * 1000;
System.out.println("onStart");
while (System.currentTimeMillis() < endTime)
{
synchronized (this)
{
try
{
wait(endTime - System.currentTimeMillis());
}
catch (Exception e)
{
}
}
}
System.out.println("---耗时任务执行完成---");
}
}希望对大家有帮助。
本文详细介绍了Android中的IntentService组件,解释了为什么在Service中不适合直接处理耗时任务,并阐述了IntentService如何通过创建独立的worker线程来处理这些任务。此外还提供了一个具体的代码示例。
282

被折叠的 条评论
为什么被折叠?



