Android中Service(后台服务)详解_Android

1.概念:
(1).Service可以说是一个在后台运行的Activity。它不是一个单独的进程,它只需要应用告诉它要在后台做什么就可以了。
(2).它要是实现和用户的交互的话需要通过通知栏或者是通过发送广播,UI去接收显示。
(3).它的应用十分广泛,尤其是在框架层,应用更多的是对系统服务的调用。
2.作用:
(1).它用于处理一些不干扰用户使用的后台操作。如下载,网络获取。播放音乐,他可以通过INTENT来开启,同时也可以绑定到宿主对象(调用者例如ACTIVITY上)来使用。
(2).如果说Activity是显示前台页面的信息,那么Service就是在后台进行操作的。如果Service和前台UI进行交互的话可以通过发送广播或者通知栏的方式。
3.生命周期:
(1).service整体的生命时间是从onCreate()被调用开始,到onDestroy()方法返回为止。和activity一样,service在onCreate()中进行它的初始化工作,在onDestroy()中释放残留的资源。
(2).**startService()的方式:**onCreate()->onStartCommand()->onStart()->onDestroy()
(3).**BindService()的方式:**onCreate()->onBinder()->onUnbind()->onDestroy()。onUnbind()方法返回后就结束了。

4.启动方式:
(1).Service自己不能运行,需要通过某一个Activity或者其它Context对象来调用。
(2).Service的启动方式有两种:
Context.startService()和Context.bindService()两种方式启动Service。如果在service的onCreate()方法或者onStart()方法中有耗时的操作,要新开启一个线程。 在需要service的地方通过以上两种方式来启动。
注意:
平常使用多的是startService方法,可以把一些耗时的任务放到后台去处理,当处理完成后,可以通过广播或者通知栏来通知前台。

5.以下通过代码来深入理解:

(1).MainActivity.java类:

package com.example.servicetest;

import com.example.servicetest.service.MyService;

import android.app.Activity;
import android.content.ComponentName;
import android.content.Intent;
import android.content.ServiceConnection;
import android.os.Bundle;
import android.os.IBinder;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class MainActivity extends Activity implements OnClickListener {
 /** 标志位 */
 private static String TAG = "com.example.servicetest.MainActivity";
 /** 启动服务 */
 private Button mBtnStart;
 /** 绑定服务 */
 private Button mBtnBind;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }

 /**
  * init the View
  */
 private void initView() {
  mBtnStart = (Button) findViewById(R.id.startservice);
  mBtnBind = (Button) findViewById(R.id.bindservice);
  mBtnStart.setOnClickListener(this);
  mBtnBind.setOnClickListener(this);

 }

 @Override
 public void onClick(View view) {
  switch (view.getId()) {
  // 启动服务的方式
  case R.id.startservice:
   startService(new Intent(MyService.ACTION));
   break;
  // 绑定服务的方式
  case R.id.bindservice:
   bindService(new Intent(MyService.ACTION), conn, BIND_AUTO_CREATE);

   break;

  default:

   break;
  }

 }

 ServiceConnection conn = new ServiceConnection() {
  public void onServiceConnected(ComponentName name, IBinder service) {
   Log.v(TAG, "onServiceConnected");
  }

  public void onServiceDisconnected(ComponentName name) {
   Log.v(TAG, "onServiceDisconnected");
  }
 };

 @Override
 protected void onDestroy() {
  super.onDestroy();
  System.out.println("-------onDestroy()--");
  stopService(new Intent(MyService.ACTION));
  unbindService(conn);
 }
}

(2).MyService.java类:

package com.example.servicetest.service;

import android.app.Service;
import android.content.Intent;
import android.os.Binder;
import android.os.IBinder;
import android.util.Log;

public class MyService extends Service {
 /** 标志位 */
 private static String TAG = "com.example.servicetest.service.MyService";
 /** 行为 */
 public static final String ACTION = "com.example.servicetest.service.MyService";

 @Override
 public void onCreate() {
  super.onCreate();

  System.out.println("----- onCreate() ---");

 }

 @Override
 public void onStart(Intent intent, int startId) {
  super.onStart(intent, startId);
  System.out.println("----- onStart() ---");
 }

 @Override
 public int onStartCommand(Intent intent, int flags, int startId) {
  System.out.println("----- onStartCommand() ---");
  return super.onStartCommand(intent, flags, startId);
 }

 @Override
 public IBinder onBind(Intent arg0) {
  System.out.println("----- onBind() ---");
  return null;
 }

 @Override
 public void onRebind(Intent intent) {
  System.out.println("----- onRebind() ---");
  super.onRebind(intent);
 }

 @Override
 public boolean onUnbind(Intent intent) {
  System.out.println("----- onUnbind() ---");
  return super.onUnbind(intent);
 }

 @Override
 public void onDestroy() {
  System.out.println("----- onDestroy() ---");
  super.onDestroy();
 }

}

(3).AndroidManifest.xml

<!-- 注册 -->
  <service android:name="com.example.servicetest.service.MyService" >
   <intent-filter>

    <!-- 用来启动服务的Intent -->
    <action android:name="com.example.servicetest.service.MyService" />

    <category android:name="android.intent.category.default" />
   </intent-filter>
  </service>

StartService方法:
(1).当按startService按钮的时候:如下:

(2).再继续按startService按钮的时候:如下:

BindService方法:

(1).当按bindService按钮的时候:如下:

(2).再继续按bindService按钮的时候:如下:

(3).先按startService按钮再按bindService按钮:如下:

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索android
, service
后台服务
android service详解、android中service详解、android service 服务、webservice注解详解、webservice wsdl 详解,以便于您获取更多的相关知识。

时间: 2024-09-19 09:12:16

Android中Service(后台服务)详解_Android的相关文章

Android中Service(后台服务)详解

  这篇文章主要介绍了Android中Service(后台服务)详解,本文讲解了Service的概念.作用.生命周期.启动方式和代码实例等内容,需要的朋友可以参考下 1.概念: (1).Service可以说是一个在后台运行的Activity.它不是一个单独的进程,它只需要应用告诉它要在后台做什么就可以了. (2).它要是实现和用户的交互的话需要通过通知栏或者是通过发送广播,UI去接收显示. (3).它的应用十分广泛,尤其是在框架层,应用更多的是对系统服务的调用. 2.作用: (1).它用于处理一

Android中HorizontalScrollView使用方法详解_Android

由于移动设备物理显示空间一般有限,不可能一次性的把所有要显示的内容都显示在屏幕上.所以各大平台一般会提供一些可滚动的视图来向用户展示数据.Android平台框架中为我们提供了诸如ListView.GirdView.ScrollView等滚动视图控件,这几个视图控件也是我们平常使用最多的.下面介绍一下HorizontalScrollView的使用和需要注意的点:  HorizontalScrollView是一个FrameLayout  ,这意味着你只能在它下面放置一个子控件,这个子控件可以包含很多

Android中persistent属性用法详解_Android

本文实例讲述了Android中persistent属性用法.分享给大家供大家参考,具体如下: 前段时间在研究telephony时,一直没有在framework下发现对telephony的初始化(PhoneFactory.Java中的makeDefaultPhones函数)的调用.结果全局搜索之后发现在application PhoneApp(packages/apps/Phone)中调用了.但是application PhoneApp既没有被Broadcast唤醒,也没有被其他service调用

Android中扫描多媒体文件操作详解_Android

这篇文章从系统源代码分析,讲述如何将程序创建的多媒体文件加入系统的媒体库,如何从媒体库删除,以及大多数程序开发者经常遇到的无法添加到媒体库的问题等.本人将通过对源代码的分析,一一解释这些问题. Android中的多媒体文件扫描机制 Android提供了一个很棒的程序来处理将多媒体文件加入的媒体库中.这个程序就是MediaProvider,现在我们简单看以下这个程序.首先看一下它的Receiver 复制代码 代码如下:     <receiver android:name="MediaSca

Android中的windowSoftInputMode属性详解_Android

    在前面的一篇文章中,简单的介绍了一下如何实现软键盘不自动弹出,使用的方法是设置android:windowSoftInputMode属性.那么,这个属性到底是干什么的,他有什么作用呢?今天这篇文章,就是探索android:windowSoftInputMode属性的作用的.     首先,我们从这个属性的名称中,可以很直观的看出它的作用,这个属性就是来设置窗口软键盘的交互模式的.     android:windowSoftInputMode属性一共有9个取值,分别是:     stat

Android中自定义进度条详解_Android

Android原生控件只有横向进度条一种,而且没法变换样式,比如原生rom的样子 很丑是吧,当伟大的产品设计要求更换前背景,甚至纵向,甚至圆弧状的,咋办,比如: ok,我们开始吧: 一)变换前背景 先来看看progressbar的属性: 复制代码 代码如下: <ProgressBar             android:id="@+id/progressBar"             style="?android:attr/progressBarStyleHor

Android中PopupWindow使用方法详解_Android

参考原文Android PopupWindow用法解析进行学习,通过实例及PopupWindow源码分析了PopupWindow的使用.文章最后的"补充Case: 弹窗不消失,但是事件向下传递"很赞. 不过,源码已经发生了变化,文章中提到的PopupViewContainer类,在目前的源码(Android6.0)中使用的是PopupBackgroundView和PopupDecorView共同完成的. 而在6.0版本的PopupWindow的preparePopup方法中,无论是否s

Android 中Manifest.xml文件详解

Android 中Manifest.xml文件详解 每一个Android项目都包含一个清单(Manifest)文件--AndroidManifest.xml,它存储在项目层次中的最底层.清单可以定义应用程序及其组件的结构和元数据. 它包含了组成应用程序的每一个组件(活动.服务.内容提供器和广播接收器)的节点,并使用Intent过滤器和权限来确定这些组件之间以及这些组件和其他应用程序是如何交互的. 它还提供了各种属性来详细地说明应用程序的元数据(如它的图标或者主题)以及额外的可用来进行安全设置和单

Android 中 ActivityLifecycleCallbacks的实例详解

Android 中 ActivityLifecycleCallbacks的实例详解 以上就是使用ActivityLifecycleCallbacks的实例,代码注释写的很清楚大家可以参考下, MyApplication如下: package com.cc; import java.util.LinkedList; import android.app.Activity; import android.app.Application; import android.os.Bundle; /** *