`

Android Service

阅读更多

 

         按自已的理解,android的Service相当于一个可以在后台运行,而不被系统当成垃圾回收的实例。当要使用该实例的时候,可以直接通过调用activity的bindService来获取。同时,该实例可以一直在后台运行,也可以不运行,但它的实例还是会长驻于后台而不被系统回收,直到调用了stopService,或者使用工具把该service停掉。

 

        使用service,有以下的步骤:

 

  1. 继承android.app.Service。
  2. 覆盖onStart,onCreate,onBind,onDestroy,onUnbind等方法。
  3. 在AndroidManifest.xml 添加<service> 节点来注册自已的service。
  4. 使用startService,stopService,bindService,unbindService来控制service。

 

 

service的生命周期很简单:

 

  1. 当调用了startService的时候,service的onCreate方法首先执行,接着执行onStart方法。
  2. 当调用了bindService方法时,service的onBind方法被调用。
  3. 当调用了unbindService方法时,service的onUnbind方法被调用。
  4. 当调用了stopService方法时,service的onDestroy方法被调用。

service的例子:

下面的例子是实现一个不继从网站上获取信息的功能,如果信息有更新,则发通一个信息到通知栏,打开通知栏后,就可以查看信息内容。网站上的数据格式在android工程目录的assets里面,把它放到自已的网站上,就可以通过该程序来获取了。

 

  • 继承Service
package com.android.test;

import java.text.SimpleDateFormat;
import java.util.ArrayList;

import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.os.Binder;
import android.os.IBinder;
import android.text.format.Time;
import android.util.Log;


/**
 * 
 * @author hhuang
 *
 */
public class MyService extends Service {
	private static final String TAG = "MyService";
	private MyBinder mBinder = new MyBinder();
	private FetchDataThread mFetcher;

	//在activity调用bindService的时候,返回service的实例给它。
	@Override
	public IBinder onBind(Intent intent) {
		Log.d(TAG, "IBinder.....");
		return mBinder;
	}

	@Override
	public void onCreate() {
		Log.d(TAG, "onCreate.....");
		super.onCreate();
	}

	@Override
	public void onStart(Intent intent, int startId) {
		Log.d(TAG, "onStart....");
		super.onStart(intent, startId);
		if(mFetcher == null){
			mFetcher = new FetchDataThread(this);
		}else{
			mFetcher.setStartTag(true);
		}
		new Thread(mFetcher).start();
	}

	
	/**
	 * 该线程不停地从网站上获取数据,如果数据有更新,则发送一个提示信息
	 * @author hhuang
	 *
	 */
	public class FetchDataThread implements Runnable {
		private boolean tag = true;
		private Context context;
		private Sms mSms;
		
		public void setStartTag(boolean tag){
			this.tag = tag;
		}
		public void stop(){
			tag = false;
		}

		public FetchDataThread(Context c) {
			context = c;
		}

		@Override
		public void run() {
			while (tag) {
				ArrayList<Sms> list = NetWork
						.reflushData("http://10.0.2.2/WebDemo/data.js");
				if (list != null && list.size() > 0) {
					Sms currentSms = list.get(0);
					Log.d("MyService:", currentSms.content + " : " + currentSms.from);
					
					if (currentSms != null && !currentSms.equals(mSms)) {
						Intent i = new Intent(context,
								NotificationActivity.class);
						i.removeExtra("content");
						i.removeExtra("from");
						i.putExtra("content", currentSms.content);
						i.putExtra("from", currentSms.from);
						
						PendingIntent pending = PendingIntent.getActivity(
								context, 0, i, PendingIntent.FLAG_UPDATE_CURRENT);
						Notification noticed = new Notification();
						noticed.icon = R.drawable.icon;
						noticed.tickerText = "New Message";
						
						noticed.defaults = Notification.DEFAULT_SOUND;
						noticed.setLatestEventInfo(context, currentSms.content, "from:" + currentSms.from,
								pending);
						
						//在打开信息提示时,自动把notification清空。
						noticed.flags = Notification.FLAG_AUTO_CANCEL;
						NotificationManager noticedManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
						noticedManager.notify(0, noticed);
						mSms = currentSms;
					}

				}

				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {

					e.printStackTrace();
				}

			}
		}

	}

	@Override
	public void onDestroy() {
		mFetcher.stop();
		Log.d(TAG, "onDestroy...");
		super.onDestroy();
	}

	@Override
	public boolean onUnbind(Intent intent) {
		Log.d(TAG, "onUnbind...");
		return super.onUnbind(intent);
	}

	public String getSystemTime() {
		Time t = new Time();
		t.setToNow();
		//SimpleDateFormat sf = new SimpleDateFormat("yyyy-dd-MM hh:mm:ss");
		return t.format("yyyy-dd-MM hh:mm:ss");
	}

	public class MyBinder extends Binder {
		MyService getService() {
			return MyService.this;
		}
	}

}
  •  在AndroidManifest.xml中注册service
....
 </activity>
        <activity android:name=".NotificationActivity"/>
        <activity android:name=".SmsViewActivity"/>
		<service android:name=".MyService" android:exported="true"/>
		
    </application>
......
  •  操作service

 

@Override
	public void onClick(View v) {
		if(v == startServiceButton) {
			Intent i = new Intent();
			i.setClass(this, MyService.class);
			this.startService(i);
			
			this.finish();
		}else if(v == stopServiceButton){
			Intent i = new Intent();
			i.setClass(this, MyService.class);
			this.stopService(i);
		}else if(v == bindServiceButton){
			Intent i = new Intent();
			i.setClass(this, MyService.class);
			this.bindService(i, mServiceConnection, BIND_AUTO_CREATE);
		}else{
			this.unbindService(mServiceConnection);
			
		}
	}
 

 

 

 

 

分享到:
评论

相关推荐

    android service 简单实例源代码

    在Android开发中,Service是四大组件之一,它在后台运行,不与用户界面直接交互,常用于执行长时间的任务,如播放音乐、网络通信等。本篇文章将深入解析"android service 简单实例源代码",帮助你理解如何在Android...

    Android Service 实现下载,前台、通知栏同步更新

    在Android应用开发中,Service是用于执行长时间运行操作的一个组件,比如后台下载任务。本教程将详细介绍如何使用Android Service来实现文件下载,并在前台显示进度,同时通过通知栏同步更新下载进度。 首先,我们...

    android service toast 01

    在Android开发中,Service是应用组件之一,它可以在后台长时间运行,即使用户界面不在活动状态。Service主要用于执行长时间运行的任务,如音乐播放、网络通信等。而`Toast`则是一种轻量级的通知方式,用于显示短暂的...

    Android service

    在Android应用开发中,"Service" 是一个非常重要的组件,它允许程序在后台长时间运行,即使用户已经离开了应用程序。在给定的标题"Android service"中,我们可以理解为讨论的是如何利用Android服务来实现特定的功能...

    Android service讲解文档ppt

    在Android应用开发中,Service是四大组件之一,它在后台执行长时间运行的操作,不与用户界面直接交互。本讲解文档将深入探讨Local Service和Remote Service的实现与使用,以及广播接收器的重要作用。 首先,我们来...

    Android Service下载,EventBus更新界面

    在Android应用开发中,Service和EventBus是两个重要的组件,它们在实现后台任务处理和界面交互方面发挥着关键作用。Service用于在后台长时间运行任务,而EventBus则是一种优秀的事件总线框架,使得组件间通信更为...

    android service的小实例

    在Android应用开发中,Service是四大组件之一,用于在后台执行长时间运行的操作,即使用户界面不在活动状态。本文将通过四个小实例详细介绍Android Service的四种启动方式:启动方式、绑定方式、线程方式以及AIDL...

    android service下载资源,同时解压资源

    在Android开发中,Service是一种非常重要的组件,它可以在后台长时间运行,执行一些不需要与用户交互的任务。本示例中,我们关注的是如何利用Service来实现资源的异步下载,并且在下载完成后对ZIP文件进行解压。这个...

    android service 学习(下)

    ### Android Service 学习(下): 进程间通信与 AIDL 在深入探讨 Android Service 的高级用法时,我们不可避免地会接触到进程间通信(IPC)这一关键概念。由于 Android 应用程序通常在各自独立的进程中运行,因此它们...

    Android Service深入解析Demo

    在Android应用开发中,Service是四大组件之一,它在后台长时间运行,不依赖于任何用户界面,用于执行长时间运行的任务,如播放音乐、网络通信等。这篇博客"Android Service深入解析Demo"通过实例深入讲解了Service的...

    Android Service简单实例

    在Android应用开发中,Service是四大组件之一,用于在后台执行长时间运行的操作,即使用户界面关闭也能继续工作。本篇文章将深入探讨`startService`类型的Android Service,通过一个简单的实例来展示其工作原理和...

    android service

    在Android系统中,Service是一种非常重要的组件,它允许应用程序在后台长时间运行操作,即使用户界面已经关闭。Service主要用于执行长时间运行的任务,如播放音乐、网络通信或者定期数据同步。本篇我们将深入探讨...

    Android-AndroidService下载文件

    在Android应用开发中,`Service` 是一个非常重要的组件,它允许应用程序在后台长时间运行操作,即使用户已经离开或关闭了应用界面。本教程将详细讲解如何利用Android的`Service` 组件来实现文件下载功能。 一、...

    android Service类简介

    Service是Android系统中的一个重要组件,它是应用程序框架的一部分,允许开发者在后台执行长时间运行的操作而无需与用户交互。这篇博客文章将深入介绍Android Service类的基本概念、功能、生命周期以及如何在实际...

    android service反馈到主线程更新界面

    在Android应用开发中,Service是实现后台长时间运行任务的关键组件,它可以脱离用户界面(UI)独立执行。在“android service反馈到主线程更新界面”这个主题中,我们主要探讨的是如何利用Service和Handler机制,...

    Android Service实现断点下载

    在Android应用开发中,Service是实现后台长时间运行任务的关键组件,比如音乐播放、网络通信以及本例中的断点续传下载。"Android Service实现断点下载"是一个实用的功能,允许用户在任意时间点暂停下载任务,并在...

    Android Service 服务不被杀死的妙招

    在Android应用开发中,Service是不可或缺的一部分,它用于在后台执行长时间运行的操作,例如播放音乐、后台数据同步等。然而,Android系统为了优化资源管理,可能会在内存紧张时杀死正在运行的Service。本文将深入...

    Android Service和Activity基于串口蓝牙模块的双向通信

    Android Service和Activity基于串口蓝牙模块的双向通信 通过本帖,我们可以了解到如何使用 Android 的 Service 和 Activity 实现基于串口蓝牙模块的双向通信。这种通信方式可以用来控制家电、智能小车等设备。 ...

    Android Service Demo

    "Android Service Demo"是一个示例项目,它展示了如何在Android应用中使用Service,尤其是结合AIDL(Android Interface Definition Language)来实现进程间通信(IPC,Inter-Process Communication)。 首先,我们...

Global site tag (gtag.js) - Google Analytics