關於android中的Service

  Android中的service類似於windows中的service,service一般沒有用戶操作界面,它運行於系統中不容易被用戶發覺,可以使用它開發如監控之類的程序。

我們可以通過如下三個方面來瞭解Service:

1、使用Service的步驟
2、如何啟動Service
3、Service的生命周期

 一、使用Service的步驟

  第一步:繼承Service類

  public class SMSService extends Service { };

  第二步:在AndroidManifest.xml文件中的節點裡對服務進行配置。

 

 二、Context.startService()和Context.bindService啟動Service

  服務不能自己運行,需要通過調用Context.startService()或Context.bindService()方法啟動服務。這兩個方法都可以啟動Service,但是它們的使用場合有所不同。

1、使用bindService()方法啟用服務,調用者與服務綁定在瞭一起,調用者一旦退出,服務也就終止。使用startService()方法啟用服務,調用者與服務之間沒有關連,即使調用者退出瞭,服務仍然運行。
2、采用Context.startService()方法啟動服務,在服務未被創建時,系統會先調用服務的onCreate()方法,接著調用onStart()方法。如果調用startService()方法前服務已經被創建,多次調用startService()方法並不會導致多次創建服務,但會導致多次調用onStart()方法。采用startService()方法啟動的服務,隻能調用Context.stopService()方法結束服務,服務結束時會調用onDestroy()方法。
3、采用Context.bindService()方法啟動服務,在服務未被創建時,系統會先調用服務的onCreate()方法,接著調用onBind()方法。這個時候調用者和服務綁定在一起,調用者退出瞭,系統就會先調用服務的onUnbind()方法,接著調用onDestroy()方法。如果調用bindService()方法前服務已經被綁定,多次調用bindService()方法並不會導致多次創建服務及綁定(也就是說onCreate()和onBind()方法並不會被多次調用)。如果調用者希望與正在綁定的服務解除綁定,可以調用unbindService()方法,調用該方法也會導致系統調用服務的onUnbind()–>onDestroy()方法。
 
 三、Service的生命周期

1、Service常用生命周期回調方法如下:
  onCreate() 該方法在服務被創建時調用,該方法隻會被調用一次,無論調用多少次startService()或bindService()方法,服務也隻被創建一次。 onDestroy()該方法在服務被終止時調用。

2、Context.startService()啟動Service有關的生命周期方法
  onStart() 隻有采用Context.startService()方法啟動服務時才會回調該方法。該方法在服務開始運行時被調用。多次調用startService()方法盡管不會多次創建服務,但onStart()方法會被多次調用。

3、Context.bindService()啟動Service有關的生命周期方法 www.aiwalls.com
  onBind()隻有采用Context.bindService()方法啟動服務時才會回調該方法。該方法在調用者與服務綁定時被調用,當調用者與服務已經綁定,多次調用Context.bindService()方法並不會導致該方法被多次調用。onUnbind()隻有采用Context.bindService()方法啟動服務時才會回調該方法。該方法在調用者與服務解除綁定時被調用。

備註:
  1. 采用startService()啟動服務

     Intent intent =new Intent(DemoActivity.this, DemoService.class);

     startService(intent);

  2.Context.bindService()啟動

     Intent intent =new Intent(DemoActivity.this, DemoService.class);

     bindService(intent, conn, Context.BIND_AUTO_CREATE);

     unbindService(conn);解除綁定

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。