展会信息港展会大全

android中intentservice简单使用
来源:互联网   发布日期:2016-01-14 09:20:01   浏览:1946次  

导读:不知道大家有没有和我一样,以前做项目或者练习的时候一直都是用Service来处理后台耗时操作,却很少注意到还有个 IntentService,前段时间准备面试的时候看到了一篇关于IntentService的解释,发现了它相对于Ser......

不知道大家有没有和我一样,以前做项目或者练习的时候一直都是用Service来处理后台耗时操作,却很少注意到还有个 IntentService,前段时间准备面试的时候看到了一篇关于IntentService的解释,发现了它相对于Service来说有很多更加方便 之处,今天在这里稍微来总结下我的心得。

首先IntentService是继承自Service的,那我们先看看Service的官方介绍,这里列出两点比较重要的地方:1.Service不是一个单独的进程 ,它和应用程序在同一个进程中。

2.Service不是一个线程,所以我们应该避免在Service里面进行耗时的操作

关于第二点我想说下,不知道很多网上的文章都把耗时的操作直接放在Service的onStart方法中,而且没有强调这样会出现 Application Not Responding!希望我的文章能帮大家认清这个误区(Service不是一个线程,不能直接处理耗时的操作)。

有人肯定会问,那么为什么我不直接用Thread而要用Service呢?关于这个,大家可以网上搜搜,这里不过多解释。有一点需要强调,如果有耗时操作在Service里,就必须开启一个单独的线程来处理!!!这点一定要铭记在心。

IntentService相对于Service来说,有几个非常有用的优点,这里主要是说IntentService使用队列的方式将请求的 Intent加入队列,然后开启一个worker thread(线程)来处理队列中的Intent,对于异步的startService请求,IntentService会处理完成一个之后再处理第二 个,每一个请求都会在一个单独的worker thread中处理,不会阻塞应用程序的主线程,这里就给我们提供了一个思路,如果有耗时的操作与其在Service里面开启新线程还不如使用 IntentService来处理耗时操作。下面给一个小例子:

1.Service:

import android.app.Service;

import android.content.Intent;

import android.os.IBinder;

public class MyService extends Service {

@Override

public void onCreate() {

super.onCreate();

}

@Override

public void onStart(Intent intent, int startId) {

super.onStart(intent, startId);

//经测试,Service里面是不能进行耗时的操作的,必须要手动开启一个工作线程来处理耗时操作

System.out.println("onStart");

try {

Thread.sleep(20000);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println("睡眠结束");

}

@Override

public IBinder onBind(Intent intent) {

return null;

}

}

2.IntentService:

import android.app.IntentService;

import android.content.Intent;

public class MyIntentService extends IntentService {

public MyIntentService() {

super("yyyyyyyyyyy");

}

@Override

protected void onHandleIntent(Intent intent) {

// 经测试,IntentService里面是可以进行耗时的操作的

//IntentService使用队列的方式将请求的Intent加入队列,然后开启一个worker thread(线程)来处理队列中的Intent

//对于异步的startService请求,IntentService会处理完成一个之后再处理第二个

System.out.println("onStart");

try {

Thread.sleep(20000);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println("睡眠结束");

}

}

测试主程序:

public class ServiceDemoActivity extends Activity {

private Button btn;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

startService(new Intent(this, MyService.class));// 主界面阻塞,最终会出现Application

// not responding

// 每次点击启动IntentService,会发现应用程序不会阻塞,而且最重的是第二次的请求会再第一个请求结束之后运行(这个证实了IntentService采用单独的线程每次只从队列中拿出一个请求进行处理)

findViewById(R.id.btnStart).setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

startService(new Intent(ServiceDemoActivity.this,

MyIntentService.class));

}

});

}

}

赞助本站

人工智能实验室

相关热词: intentservice

相关内容
AiLab云推荐
推荐内容
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港