一。生命周期:

startService()方式启动,Service是通过接受Intent并且会经历onCreate()和onStart()。当用户在发出意图使之销毁时会经历onDestroy();( onCreate-->onStart-->onDestory )

bindService()方式启动,与Activity绑定的时候,会经历onCreate()和onBind(),而当Activity被销毁的时候,Service会先调用onUnbind()然后是onDestroy()。( onCreate-->onBind -->onUnbind-->onDestory)

二。控制方式:

StartService的控制方式需要使用固定的方法,对Service进行单一的操作。

而BindService由于与Activity绑定,不用考虑其生命周期问题,并且从发送Intent的被动操作,变为可以主动对Service对象进行操作,我们甚至可以建立一个Handler类,对Service进行相关的操作。大大加强了Service的灵活性、可操作性。

总结:对于简单的应用startService()启动方式能带来更少的代码,简单的操作。对于复杂的应用bindService()方式,虽然带来的更多的编码,但同时也带来了更好的可操作性,使其使用起来更像Activity。

注意:

Service的生命周期方法比Activity少一些,只有onCreate, onStart, onDestroy 我们有两种方式启动一个Service,他们对Service生命周期的影响是不一样的。

1 通过startService 
Service会经历 onCreate --> onStart

stopService的时候直接onDestroy,如果是 调用者 直接退出而没有调用stopService的话,Service会一直在后台运行,下次调用者再起来仍然可以stopService。

2 通过bindService 
Service只会运行onCreate, 这个时候 调用者和Service绑定在一起,调用者退出了,Srevice就会调用onUnbind-->onDestroyed,所谓绑定在一起就共存亡了。

注意:Service的onCreate的方法只会被调用一次,
就是你无论多少次的startService又 bindService,Service只被创建一次。
如果先是bind了,那么start的时候就直接运行Service的onStart方法,
如果先是start,那么bind的时候就直接运行onBind方法。如果你先bind上了,就stop不掉了,
只能先UnbindService, 再StopService,所以是先start还是先bind行为是有区别的。

代码:

一。startService -->service内容:

public class MyService extends Service{

    private static final String TAG = "MyService";
MediaPlayer player; @Override
public IBinder onBind(Intent intent) {
return null;
} @Override
//服务启动前进行的配置
public void onCreate() {
Toast.makeText(this, "My Service created", Toast.LENGTH_LONG).show();
Log.i(TAG, "onCreate"); //播放设置
player = MediaPlayer.create(this, R.raw.music);//提供音乐的位置
player.setLooping(false); //是否循环播放音乐
} @Override
//关闭服务
public void onDestroy() {
Toast.makeText(this, "My Service Stoped", Toast.LENGTH_LONG).show();
Log.i(TAG, "onDestroy");
player.stop();
} @Override
//启动服务
public void onStart(Intent intent, int startid) {
Toast.makeText(this, "My Service Start", Toast.LENGTH_LONG).show();
Log.i(TAG, "onStart");
player.start();
} } Activity的内容:
public class Activityone extends Activity{

    private static final String TAG = "ServiceDemo";
private Button mybuttonone1;
private Button mybuttonone2; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_one); mybuttonone1 = (Button)findViewById(R.id.buttonone1);
mybuttonone2 = (Button)findViewById(R.id.buttonone2); //service通过startservice启动服务
//首先调用mybuttonone1的onclick方法,然后调用myservice的onclick()方法,再然后调用onstart()方法
mybuttonone1.setOnClickListener(new OnClickListener() { @Override
public void onClick(View v) {
Log.i(TAG, "onClick: starting service");
startService(new Intent(Activityone.this, MyService.class));
}
}); //service通过startservice关闭服务
//首先调用mybuttonone2的onclick方法,然后调用myservice的onstop()方法 mybuttonone2.setOnClickListener(new OnClickListener() { @Override
public void onClick(View v) {
Log.i(TAG, "onClick: stopping service");
stopService(new Intent(Activityone.this, MyService.class));
}
}); mybuttonone1.setOnClickListener(new myclicklistener());
mybuttonone2.setOnClickListener(new myclicklistener()); } class myclicklistener implements OnClickListener{
public void onClick(View src) {
switch (src.getId()) {
case R.id.buttonone1:
Log.i(TAG, "onClick: starting service");
startService(new Intent(Activityone.this, MyService.class));
//startservice 执行的步骤: onclick()-->onstart()
break;
case R.id.buttonone2:
Log.i(TAG, "onClick: stopping service");
stopService(new Intent(Activityone.this, MyService.class));
//startservice 执行的步骤: onDestroy()
break;
}
}
} } 二。BindService -->service内容:
public class BindService extends Service {

    private MyBinder myBinder = new MyBinder();
private static final String TAG = "BindService";
private MediaPlayer play; @Override
public IBinder onBind(Intent intent) {
Log.i(TAG, "BindService-->onBind()"); play=MediaPlayer.create(this, R.raw.music);
play.setLooping(false); return myBinder;
} public class MyBinder extends Binder{ public BindService getService(){
Log.i(TAG, "BindService-->getService()");
return BindService.this;
}
} public void MyMethod(){
Log.i(TAG, "BindService-->MyMethod()");
play.start();
} } Activity的代码:
public class Activitytwo extends Activity{

    private Button mybutton1;
private Button mybutton2;
private boolean flag; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_two); mybutton1=(Button)findViewById(R.id.buttontwo1);
mybutton2=(Button)findViewById(R.id.buttontwo2); mybutton1.setOnClickListener(new myclicklistener());
mybutton2.setOnClickListener(new myclicklistener()); } class myclicklistener implements OnClickListener{ @Override
public void onClick(View v) {
// TODO Auto-generated method stub
switch (v.getId()) {
case R.id.buttontwo1:
System.out.println("打开bind1");
bindService();
break; case R.id.buttontwo2:
System.out.println("关闭bind1");
unBind();
break; default:
break;
}
}
} private void bindService(){
System.out.println("打开bind2");
Intent intent = new Intent(Activitytwo.this,BindService.class);
bindService(intent, conn, Context.BIND_AUTO_CREATE);
} private void unBind(){
System.out.println("关闭bind2");
if(flag == true){
unbindService(conn);
flag = false;
}
} private ServiceConnection conn = new ServiceConnection() { @Override
public void onServiceDisconnected(ComponentName name) {
System.out.println("关闭bind3");
} @Override
public void onServiceConnected(ComponentName name, IBinder service) {
System.out.println("打开bind3");
MyBinder binder = (MyBinder)service;
BindService bindService = binder.getService();
bindService.MyMethod();
flag = true;
}
}; }

浅谈Service的更多相关文章

  1. 浅谈Service层为何要有接口

    被人随意问了一句,为何每个service层都要写一个接口呢,多麻烦~虽然想说点什么,但是又不知道从何说起,只好从新整理一下思绪. 情景1:在开源框架中有很多这种情况,就是某个功能支持用户自定义扩展.说 ...

  2. 安卓开发_浅谈Service

    一.Service(服务) Service是Android程序中四大基础组件之一,它和Activity一样都是Context的子类,区别在于它没有UI界面,是在后台运行的组件. public abst ...

  3. 浅谈Service Manager成为Android进程间通信(IPC)机制Binder守护进程之路

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6621566 上一篇文章Android进程间通信 ...

  4. 浅谈service、DAO层引入(转)

    转自 http://www.4u4v.net/mvc-simple-enough-on-the-introduction-of-service-dao-layer.html MVC是web开发中常见的 ...

  5. 浅谈Android系统进程间通信(IPC)机制Binder中的Server和Client获得Service Manager接口之路

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6627260 在前面一篇文章浅谈Service ...

  6. Web Service进阶(七)浅谈SOAP Webservice和RESTful Webservice

    浅谈SOAP Webservice和RESTful Webservice REST是一种架构风格,其核心是面向资源,REST专门针对网络应用设计和开发方式,以降低开发的复杂性,提高系统的可伸缩性.RE ...

  7. 浅谈 kubernetes service 那些事(上篇)

    一.问题 首先,我们思考这样一个问题: 访问k8s集群中的pod, 客户端需要知道pod地址,需要感知pod的状态.那如何获取各个pod的地址?若某一node上的pod故障,客户端如何感知? 二.k8 ...

  8. 浅谈 kubernetes service 那些事 (下篇)

    欢迎访问网易云社区,了解更多网易技术产品运营经验. 五.K8s 1.8 新特性--ipvs ipvs与iptables的性能差异 随着服务的数量增长,IPTables 规则则会成倍增长,这样带来的问题 ...

  9. Service Cloud 零基础(一)Case 浅谈

    本片参考:https://resources.docs.salesforce.com/222/latest/en-us/sfdc/pdf/salesforce_case_implementation_ ...

随机推荐

  1. JQuery学习之遍历

    1.祖先:向上遍历DOM树 **parent():返回被选中元素的直接父元素,该方法只会向上一级对DOM树进行遍历 $(document).ready(function(){ $("span ...

  2. 破解ZIP加密文件密码fcrackzip

    破解ZIP加密文件密码fcrackzip ZIP是最常见的文件压缩方式.由于其压缩算法开源,主流操作系统都支持这种压缩算法.ZIP压缩方式支持密码加密.加密的时候会在文件头部保存密钥相关信息.利用这个 ...

  3. 为什么下载APP,扫描二维码,关注微信公众号,就会送牛奶送小礼品?下载使用量高,会怎样?

    以前的老办法是到处贴广告,电视上,广播上各种宣传. 在互联网时代,企业要盈利,除了不断优化升级自己的产品和服务,大量推广宣传产品,还要懂得用户思维.现在有网站,有APP,有微信,有二维码,可以卖产品, ...

  4. css3 -- 颜色与不透明度

    1.opacity: opacity的值会被它的所有子元素继承,也就是说不可能让一个元素比他的父元素更加不透明,但你可以让他变得更透明点 Firefox  Webkit  Opera支持,注意IE 2 ...

  5. MFC 打开其他程序

    WinExec("程序路径",SW_SHOW);

  6. SolrCloud zookeeper节点信息

    shard 节点列表 get /collections/appstore/leaders/shard1 { "core":"appstore", "n ...

  7. BZOJ 1013 & 高斯消元

    题意: 告诉你一个K维球体球面上的K+1个点问球心坐标. sol: 乍一看还以为是K维的二分答案然后判断距离...真是傻逼了...你看乱七八糟的题目做多了然后就会忘记最有用的基本计算... 我们可以看 ...

  8. [深入浅出Windows 10]分屏控件(SplitView)

    4.18 分屏控件(SplitView) 分屏控件(SplitView)是Windows 10新增的控件类型,也是Windows 10通用应用程序主推的交互控件,通常和一个汉堡按钮搭配作为一种抽屉式菜 ...

  9. 【BZOJ】2675: Bomb

    题意: 给n个点,任选其中3个点(一个点只能取一次),求选出三个点的最大曼哈顿距离之和与最小曼哈顿距离之和(n<=10^5). 题解: 最大曼哈顿距离之和很好求,就是能包围所有点的经过三个点的矩 ...

  10. 【BZOJ】3434: [Wc2014]时空穿梭

    http://www.lydsy.com/JudgeOnline/problem.php?id=3434 题意:n维坐标中要找c个点使得c个点在一条线上且每一维的坐标单调递增且不能超过每一维限定的值m ...