Service 简介:

Service分为本地服务(LocalService)和远程服务(RemoteService):

1、本地服务依附在主进程上而不是独立的进程,这样在一定程度上节约了资源,另外Local服务因为是在同一进程因此不需要IPC,也不需要AIDL。相应bindService会方便很多。主进程被Kill后,服务便会终止。

2、远程服务为独立的进程,对应进程名格式为所在包名加上你指定的android:process字符串。由于是独立的进程,因此在Activity所在进程被Kill的时候,该服务依然在运行,不受其他进程影响,有利于为多个进程提供服务具有较高的灵活性。该服务是独立的进程,会占用一定资源,并且使用AIDL进行IPC稍微麻烦一点。

按使用方式可以分为以下三种:

1、startService 启动的服务:主要用于启动一个服务执行后台任务,不进行通信。停止服务使用stopService;

2、bindService 启动的服务:该方法启动的服务可以进行通信。停止服务使用unbindService;

3、startService 同时也 bindService 启动的服务:停止服务应同时使用stepService与unbindService

Service的生命周期

onCreate -- onStart -- onDestroy -- onBind

1). 被启动的服务的生命周期:如果一个Service被某个Activity 调用 Context.startService 方法启动,那么不管是否有Activity使用bindService绑定或unbindService解除绑定到该Service,该Service都在后台运行。如果一个Service被startService 方法多次启动,那么onCreate方法只会调用一次,onStart将会被调用多次(对应调用startService的次数),并且系统只会创建Service的一个实例(因此你应该知道只需要一次stopService调用)。该Service将会一直在后台运行,而不管对应程序的Activity是否在运行,直到被调用stopService,或自身的stopSelf方法。当然如果系统资源不足,android系统也可能结束服务。

2). 被绑定的服务的生命周期:如果一个Service被某个Activity 调用 Context.bindService 方法绑定启动,不管调用 bindService 调用几次,onCreate方法都只会调用一次,同时onStart方法始终不会被调用。当连接建立之后,Service将会一直运行,除非调用Context.unbindService 断开连接或者之前调用bindService 的 Context 不存在了(如Activity被finish的时候),系统将会自动停止Service,对应onDestroy将被调用。

3). 被启动又被绑定的服务的生命周期:如果一个Service又被启动又被绑定,则该Service将会一直在后台运行。并且不管如何调用,onCreate始终只会调用一次,对应startService调用多少次,Service的onStart便会调用多少次。调用unbindService将不会停止Service,而必须调用 stopService 或 Service的 stopSelf 来停止服务。

4). 当服务被停止时清除服务:当一个Service被终止(1、调用stopService;2、调用stopSelf;3、不再有绑定的连接(没有被启动))时,onDestroy方法将会被调用,在这里你应当做一些清除工作,如停止在Service中创建并运行的线程。

特别注意:

1、你应当知道在调用 bindService 绑定到Service的时候,你就应当保证在某处调用 unbindService 解除绑定(尽管 Activity 被 finish 的时候绑定会自      动解除,并且Service会自动停止);

2、你应当注意 使用 startService 启动服务之后,一定要使用 stopService停止服务,不管你是否使用bindService;

3、同时使用 startService 与 bindService 要注意到,Service 的终止,需要unbindService与stopService同时调用,才能终止 Service,不管 startService 与 bindService 的调用顺序,如果先调用 unbindService 此时服务不会自动终止,再调用 stopService 之后服务才会停止,如果先调用 stopService 此时服务也不会终止,而再调用 unbindService 或者 之前调用 bindService 的 Context 不存在了(如Activity 被 finish 的时候)之后服务才会自动停止;

4、当在旋转手机屏幕的时候,当手机屏幕在“横”“竖”变换时,此时如果你的 Activity 如果会自动旋转的话,旋转其实是 Activity 的重新创建,因此旋转之前的使用 bindService 建立的连接便会断开(Context 不存在了),对应服务的生命周期与上述相同。

5、在 sdk 2.0 及其以后的版本中,对应的 onStart 已经被否决变为了 onStartCommand,不过之前的 onStart 任然有效。这意味着,如果你开发的应用程序用的 sdk 为 2.0 及其以后的版本,那么你应当使用 onStartCommand 而不是 onStart。

Android中Thread和Service的区别zz - petercao - 博客园
http://www.cnblogs.com/bluestorm/p/5704264.html

LocalService代码示例:

首先,因为要再Manifest文件里对服务进行注册,所以就先来Manifest的代码吧~

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"
  3. package="com.test.localservice" android:versionCode="1"
  4. android:versionName="1.0">
  5. <uses-sdk android:minSdkVersion="8" />
  6. <application android:icon="@drawable/icon" android:label="@string/app_name">
  7. <activity android:name=".LocalServiceTestActivity"
  8. android:label="@string/app_name">
  9. <intent-filter>
  10. <action android:name="android.intent.action.MAIN" />
  11. <category android:name="android.intent.category.LAUNCHER" />
  12. </intent-filter>
  13. </activity>
  14. <service android:name=".MyService">
  15. <intent-filter>
  16. <action android:name="com.test.SERVICE_TEST" />
  17. <category android:name="android.intent.category.default" />
  18. </intent-filter>
  19. </service>
  20. </application>
  21. </manifest>

然后然后,是服务实现类~

  1. package com.test.service;
  2. import android.app.Service;
  3. import android.content.Intent;
  4. import android.os.Binder;
  5. import android.os.IBinder;
  6. import android.util.Log;
  7. public class MyService extends Service {
  8. public class LocalBinder extends Binder {
  9. String stringToSend = "I'm the test String";
  10. MyService getService() {
  11. Log.i("TAG", "getService ---> " + MyService.this);
  12. return MyService.this;
  13. }
  14. }
  15. private final IBinder mBinder = new LocalBinder();
  16. @Override
  17. public IBinder onBind(Intent intent) {
  18. Log.i("TAG", "onBind~~~~~~~~~~~~");
  19. return mBinder;
  20. }
  21. @Override
  22. public void onCreate() {
  23. super.onCreate();
  24. Log.i("TAG", "onCreate~~~~~~~~~~");
  25. }
  26. @Override
  27. public void onDestroy() {
  28. super.onDestroy();
  29. Log.i("TAG", "onDestroy~~~~~~~~~~~");
  30. }
  31. @Override
  32. public void onStart(Intent intent, int startId) {
  33. super.onStart(intent, startId);
  34. Log.i("TAG", "onStart~~~~~~");
  35. }
  36. @Override
  37. public int onStartCommand(Intent intent, int flags, int startId) {
  38. Log.i("TAG", "onStartCommand~~~~~~~~~~~~");
  39. return super.onStartCommand(intent, flags, startId);
  40. }
  41. @Override
  42. public boolean onUnbind(Intent intent) {
  43. Log.i("TAG", "onUnbind~~~~~~~~~~~~~~~~");
  44. return super.onUnbind(intent);
  45. }
  46. }

再来,就是我们的Activity的测试类啦~

    1. <pre name="code" class="java">package com.test.service;
    2. import android.app.Activity;
    3. import android.content.ComponentName;
    4. import android.content.Context;
    5. import android.content.Intent;
    6. import android.content.ServiceConnection;
    7. import android.media.MediaPlayer;
    8. import android.os.Bundle;
    9. import android.os.IBinder;
    10. import android.util.Log;
    11. import android.view.View;
    12. import android.view.View.OnClickListener;
    13. import android.widget.Button;
    14. public class ServiceTestActivity extends Activity {
    15. private Button startButton, bindButton;
    16. private Button stopButton, unbindButton;
    17. private ServiceConnection sc;
    18. private MediaPlayer mediaPlayer = null;
    19. private MyService myService;
    20. @Override
    21. public void onCreate(Bundle savedInstanceState) {
    22. super.onCreate(savedInstanceState);
    23. setContentView(R.layout.main);
    24. startButton = (Button) findViewById(R.id.startbutton_id);
    25. stopButton = (Button) findViewById(R.id.stopbutton_id);
    26. bindButton = (Button) findViewById(R.id.bindbutton_id);
    27. unbindButton = (Button) findViewById(R.id.unbindbutton_id);
    28. sc = new ServiceConnection() {
    29. @Override
    30. public void onServiceConnected(ComponentName name, IBinder service) {
    31. myService = ((MyService.LocalBinder) service).getService();
    32. String recStr = ((MyService.LocalBinder) service).stringToSend;
    33. Log.i("TAG","The String is : " + recStr);
    34. Log.i("TAG", "onServiceConnected : myService ---> " + myService);
    35. }
    36. @Override
    37. public void onServiceDisconnected(ComponentName name) {
    38. sc = null;
    39. Log.i("TAG", "onServiceDisconnected : ServiceConnection --->"
    40. + sc);
    41. }
    42. };
    43. startButton.setOnClickListener(new OnClickListener() {
    44. @Override
    45. public void onClick(View v) {
    46. Intent intent = new Intent(ServiceTestActivity.this,
    47. MyService.class);
    48. startService(intent);
    49. Log.i("TAG", "Start button clicked");
    50. }
    51. });
    52. stopButton.setOnClickListener(new OnClickListener() {
    53. @Override
    54. public void onClick(View v) {
    55. Intent intent = new Intent();
    56. intent.setAction("com.test.SERVICE_TEST");
    57. stopService(intent);
    58. Log.i("TAG", "Stop Button clicked");
    59. }
    60. });
    61. bindButton.setOnClickListener(new OnClickListener() {
    62. @Override
    63. public void onClick(View v) {
    64. Intent intent = new Intent();
    65. intent.setAction("com.test.SERVICE_TEST");
    66. bindService(intent, sc, Context.BIND_AUTO_CREATE);
    67. Log.i("TAG", "Bind button clicked");
    68. }
    69. });
    70. unbindButton.setOnClickListener(new OnClickListener() {
    71. @Override
    72. public void onClick(View v) {
    73. unbindService(sc);
    74. Log.i("TAG", "Unbind Button clicked");
    75. }
    76. });
    77. }
    78. }

Android中Service 使用详解(LocalService + RemoteService)的更多相关文章

  1. Android中Service(服务)详解

    http://blog.csdn.net/ryantang03/article/details/7770939 Android中Service(服务)详解 标签: serviceandroidappl ...

  2. Android中mesure过程详解

    我们在编写layout的xml文件时会碰到layout_width和layout_height两个属性,对于这两个属性我们有三种选择:赋值成具体的数值,match_parent或者wrap_conte ...

  3. Android中Intent组件详解

    Intent是不同组件之间相互通讯的纽带,封装了不同组件之间通讯的条件.Intent本身是定义为一个类别(Class),一个Intent对象表达一个目的(Goal)或期望(Expectation),叙 ...

  4. Android中的动画详解系列【4】——Activity之间切换动画

    前面介绍了Android中的逐帧动画和补间动画,并实现了简单的自定义动画,这一篇我们来看看如何将Android中的动画运用到实际开发中的一个场景--Activity之间跳转动画. 一.定义动画资源 如 ...

  5. 【转载】Android Studio Service AIDL 详解

    公司产品之前IM这块存在很多问题,消息到达率低,加上协议上有些问题,丢消息频繁,所以需要重构IM,AIDL不能解决以上问题.好吧!那AIDL可以解决什么问题?什么是AIDL? 什么是AIDL? AID ...

  6. Android中shape属性详解

    一.简单使用 刚开始,就先不讲一堆标签的意义及用法,先简单看看shape标签怎么用. 1.新建shape文件 首先在res/drawable文件夹下,新建一个文件,命名为:shape_radius.x ...

  7. RxJava在Android中使用场景详解

    RxJava 系列文章 <一,RxJava create操作符的用法和源码分析> <二,RxJava map操作符用法详解> <三,RxJava flatMap操作符用法 ...

  8. Android中的Intent详解

    前言: 每个应用程序都有若干个Activity组成,每一个Activity都是一个应用程序与用户进行交互的窗口,呈现不同的交互界面.因为每一个Acticity的任务不一样,所以经常互在各个Activi ...

  9. Android中SQLite应用详解

    上次我向大家介绍了SQLite的基本信息和使用过程,相信朋友们对SQLite已经有所了解了,那今天呢,我就和大家分享一下在Android中如何使用SQLite. 现在的主流移动设备像Android.i ...

随机推荐

  1. 安装ssh服务

    1.先更新下源 sudo apt-get update 2.安装ssh服务 sudo apt-get openssh-server 3.配置ssh-server,配置文件位于/etc/ssh/sshd ...

  2. PyQt4软件打包成exe文件

    使用py2exe进行打包 例: from distutils.core import setupimport py2exeimport sys sys.argv.append('py2exe') py ...

  3. Nginx 使用 sever 段规则屏蔽恶意 User Agent

    相对于 Apache,Nginx 占用的系统资源更少,更适合 VPS 使用.恶意的 User Agent 无处不在,博客更换到 WordPress 没几天,就被 SPAM(垃圾留言)盯上,又被暴力破解 ...

  4. MySQL 编程的6个重要的技巧

    一.每一行命令都是用分号(;)作为结束 对于MySQL,第一件你必须牢记的是它的每一行命令都是用分号(;)作为结束的,但当一行MySQL被插入在PHP代码中时,最好把后面的分号省略掉,例如:   二. ...

  5. Oracle: SQL组合不同字段作为一个查询条件

    前端程序传过来的值是有三个字段组合之后的结果,后端程序处理,并且将查询的数据反馈给前端. PS:不能直接使用字段RPT_NO的,因为在这条记录中RPT_NO恰好等于其他三个字段的组合值. 正确的做法是 ...

  6. Install OE and BitBake

    LeapFrog Explorers: Install OE and BitBake - eLinux.org     http://elinux.org/LeapFrog_Explorers:_In ...

  7. 通过nsenter连接docker容器

    通常连接Docker容器并与其进行交互有四种方法.详情见:https://github.com/berresch/Docker-Enter-Demo,下面摘录nsenter连接的方式. 查看是否安装n ...

  8. FFmpeg-20160413-snapshot-bin

    ESC 退出 0 进度条开关 1 屏幕原始大小 2 屏幕1/2大小 3 屏幕1/3大小 4 屏幕1/4大小 S 下一帧 [ -2秒 ] +2秒 ; -1秒 ' +1秒 下一个帧 -> -5秒 F ...

  9. winform,wpf,winrt获取屏幕分辨率

    winform 当前的屏幕除任务栏外的工作域大小     this.Width = System.Windows.Forms.Screen.PrimaryScreen.WorkingArea.Widt ...

  10. 【leetcode】atoi (hard) ★

    虽然题目中说是easy, 但是我提交了10遍才过,就算hard吧. 主要是很多情况我都没有考虑到.并且有的时候我的规则和答案中的规则不同. 答案的规则: 1.前导空格全部跳过  “      123” ...