zoukankan      html  css  js  c++  java
  • Android入门-Service-start,end,bind,unbind之间的区别

    写贴一段别人关于service中start与bind,end与unbind的分析了:

    Service创建有两种方法:  startService或者bindService

    服务不能自己运行,需要通过调用Context.startService()或Context.bindService()方法启动服务。这两个方法都可以启动Service,但是它们的使用场合有所不同。

    使用startService()方法启用服务,调用者与服务之间没有关连,即使调用者退出了,服务仍然运行。

    使用bindService()方法启用服务,调用者与服务绑定在了一起,调用者一旦退出,服务也就终止,大有“不求同时生,必须同时死”的特点。


    如果打算采用Context.startService()方法启动服务,在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onStart()方法。如果调用startService()方法前服务已经被创建,多次调用startService()方法并不会导致多次创建服务,但会导致多次调用onStart()方法。采用startService()方法启动的服务,只能调用Context.stopService()方法结束服务,服务结束时会调用onDestroy()方法。


    如果打算采用Context.bindService()方法启动服务,在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onBind()方法。这个时候调用者和服务绑定在一起,调用者退出了,系统就会先调用服务的onUnbind()方法,接着调用onDestroy()方法。如果调用bindService()方法前服务已经被绑定,多次调用bindService()方法并不会导致多次创建服务及绑定(也就是说onCreate()和onBind()方法并不会被多次调用)。如果调用者希望与正在绑定的服务解除绑定,可以调用unbindService()方法,调用该方法也会导致系统调用服务的onUnbind()-->onDestroy()方法。

    看得好像好复杂的样子,其实有个比较简单的理解,那就是:

    (1)浅显的区别start和bind;

    (2)start的服务可以被end,bind的服务end无法让他destory;

    (3)bind的服务必须要unbind才能destroy;

    (4)服务可以多次bind(好像没意义吧),但是只能unbind一次。

    (5)不能unbind未被bind的服务。

    顺便提下怎样查看一项服务是否在运行的方法:

    [java] view plaincopy
     
    1. private String isRunning(Context context) {  
    2.     ActivityManager am = (ActivityManager) context  
    3.             .getSystemService(Context.ACTIVITY_SERVICE);  
    4.     List<RunningServiceInfo> list = am.getRunningServices(30);  
    5.   
    6.     for (RunningServiceInfo info : list) {  
    7.         if ((info.service.getClassName()).equals("com.fred.app.MyService")) {  
    8.             return "running......";  
    9.         }  
    10.     }  
    11.     return "stopped......";  
    12. }  

    我这里有一个实例,小伙伴可以下载了跑着看看,就大概能知道区别了。

    http://download.csdn.net/detail/mrdemigod/6453585

  • 相关阅读:
    Truck History(poj 1789)
    Highways poj 2485
    117. Populating Next Right Pointers in Each Node II
    116. Populating Next Right Pointers in Each Node
    115. Distinct Subsequences
    114. Flatten Binary Tree to Linked List
    113. Path Sum II
    109. Convert Sorted List to Binary Search Tree
    106. Construct Binary Tree from Inorder and Postorder Traversal
    105. Construct Binary Tree from Preorder and Inorder Traversal
  • 原文地址:https://www.cnblogs.com/xiaorenwu702/p/4413998.html
Copyright © 2011-2022 走看看