欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Service与Activity之间的通信(同一进程)

程序员文章站 2024-02-27 23:54:57
一、当acitivity和service处于同一个application和进程时,通过继承binder类来实现。 当一个activity绑定到一个service上时,它负...

一、当acitivity和service处于同一个application和进程时,通过继承binder类来实现。

当一个activity绑定到一个service上时,它负责维护service实例的引用,允许你对正在运行的service进行一些方法调用。比如你后台有一个播放背景音乐的service,这时就可以用这种方式来进行通信。

代码如下:

/*************************service代码****************************************
/public class localservice extends service {
private final ibinder binder = new localbinder(); 
public class localbinder extends binder { 
localservice getservice() { 
return localservice.this; 
} 
} public ibinder onbind(intent intent) { 
return binder; 
} 
} 
/*****************************activity代码*************************************/public class bindingactivity extends activity { 
localservice localservice; 
private serviceconnection mconnection = new serviceconnection() { 
public void onserviceconnected(componentname classname,ibinder localbinder) { localservice = (localbinder) localbinder.getservice(); 
} 
public void onservicedisconnected(componentname arg0) { 
localservice = null; 
} 
}; 
protected void onstart() { 
super.onstart(); 
intent intent = new intent(this, localservice.class); 
bindservice(intent, mconnection, context.bind_auto_create); 
} 
protected void onstop() { 
super.onstop(); 
unbindservice(mconnection); 
} 
public void printrandomnumber{ 
int num = localservice.getrandomnumber(); 
system.out.println(num); 
}
}

代码解释:

使用使用context.bindservice()启动service会经历:

context.bindservice()->oncreate()->onbind()->service running
onunbind() -> ondestroy() ->service stop

activity能进行绑定得益于service的接口onbind()。service和activity的连接可以用serviceconnection来实现,需要实现一个新的serviceconnection,重写onserviceconnected和onservicedisconnected方法。执行绑定,调用bindservice方法,传入一个选择了要绑定的service的intent(显式或隐式)和一个你实现了的serviceconnection实例。一旦连接建立,你就能通service的接口onbind()得到servicebinder实例进而得到service的实例引用。一旦service对象找到,就能得到它的公共方法和属性。但这种方式,一定要在同一个进程和同一个application里。

如何检验activity和service是否是在同一个进程中运行

一般情况下,activity和service在同一个包名内,并且没有设定属性android:process=":remote",两者在同一个进程中。

因为一个进程只有一个ui线程,所以两者就在同一个线程里。

如果设置android:process=":remote",就属于跨进程访问,就属于不同的进程了。

验证方法:

在activiyt和service的oncreate中打印进程的信息

如log.i("tag",thread.curentthread().getid());