測试Service
<strong><span style="font-size:18px;">自己定义Service:</span></strong>
/**
* Created by liuwang on 15-3-15.
*/
public class MyService extends Service { private MBinder mBinder = new MBinder(); public MyService() {
super();
System.out.println("MyService---");
} @Override
public IBinder onBind(Intent intent) {
System.out.println("onBind---");
return mBinder;
} @Override
public void onCreate() {
super.onCreate();
System.out.println("onCreate---");
} @Override
public void onStart(Intent intent, int startId) {
super.onStart(intent, startId);
System.out.println("onStart---");
} @Override
public int onStartCommand(Intent intent, int flags, int startId) {
System.out.println("onStartCommand---");
return super.onStartCommand(intent, flags, startId);
} @Override
public boolean onUnbind(Intent intent) {
System.out.println("onUnbind---");
return super.onUnbind(intent);
} @Override
public void onDestroy() {
super.onDestroy();
System.out.println("onDestroy---");
} @Override
public void onRebind(Intent intent) {
super.onRebind(intent);
System.out.println("onRebind---");
} @Override
public void onTaskRemoved(Intent rootIntent) {
super.onTaskRemoved(rootIntent);
System.out.println("onTaskRemoved---");
} @Override
protected void dump(FileDescriptor fd, PrintWriter writer, String[] args) {
super.dump(fd, writer, args);
System.out.println("dump---");
} @Override
public void onTrimMemory(int level) {
super.onTrimMemory(level);
System.out.println("onTrimMemory---");
} @Override
public void onLowMemory() {
super.onLowMemory();
System.out.println("onLowMemory---");
} @Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
System.out.println("onConfigurationChanged---");
} class MBinder extends Binder { } }
Activity:
public class MainActivity extends ActionBarActivity implements View.OnClickListener { private Button start;
private Button finish;
private Button onbind;
private Button unbind;
private Intent intent;
private ServiceConnection sc; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); start = (Button) findViewById(R.id.start);
finish = (Button) findViewById(R.id.finish);
onbind = (Button) findViewById(R.id.onbind);
unbind = (Button) findViewById(R.id.unbind); start.setOnClickListener(this);
finish.setOnClickListener(this);
onbind.setOnClickListener(this);
unbind.setOnClickListener(this); intent = new Intent();
intent.setClass(this,MyService.class); sc = new ServiceConnection() {
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
System.out.println("连接成功");
} @Override
public void onServiceDisconnected(ComponentName name) {
System.out.println("连接失败");
}
}; } @Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.start:
startService(intent);
break;
case R.id.finish:
stopService(intent);
break;
case R.id.onbind:
bindService(intent,sc,BIND_AUTO_CREATE);
break;
case R.id.unbind:
unbindService(sc); break;
}
}
}
測试1:
当点击启动Service时的流程:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMjcwNjc1OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
在点击绑定:
点击解绑:
最后点击关闭服务:
測试2:
点击绑定:
点击启动:
点击关闭服务:
无输出。
点击解除绑定:
总结:
当我进行启动服务和绑定服务后,假设仅仅是关闭服务或解绑服务并不会将service杀死。
当我进行启动服务后在绑定。并不会反复创建service。
先启动在绑定的流程:构造方法->oncreate->onstartcommand->onstart->onbind->onserviceconnection
先绑定service在启动service流程:构造方法->oncreate->onbind->onserviceconnection->onstartcommand->onstart
当我反复启动service仅仅会反复调用startcommand和start方法,不会反复调用oncreate
当我进行多次绑定时并不会反复创建多个service
当我绑定service而且退出activity不解绑service时,service会自己主动被关闭,而且logcat会报错
我能够利用绑定service后启动service然后退出activity解绑service,这样service还不会被kill。再次进入activity我们能够通过关闭service使service关闭。
測试Service的更多相关文章
- zTree实现地市县三级级联Service接口測试
zTree实现地市县三级级联Service接口測试 ProvinceServiceTest.java: /** * @Title:ProvinceServiceTest.java * @Package ...
- CAS(Central Authentication Service)——windows上简单搭建及測试
入手文章,大神绕行. 一.服务端搭建 我使用的服务端版本号为:cas-server-3.4.11-release.zip.解压之后,将\cas-server-3.4.11-release\cas-se ...
- java 搭建webservice服务+testclient測试
整理别人的日志: 一.什么是webservice 一种构建应用程序的普遍模型,能够在不论什么支持网络通信的操作系统中执行.一种新的web应用程序分支,能够公布.定位通过web调用.它是一个应用组件,为 ...
- Maven实现Web应用集成測试自己主动化 -- 部署自己主动化(WebTest Maven Plugin)
上篇:Maven实现Web应用集成測试自己主动化 -- 測试自己主动化(WebTest Maven Plugin) 之前介绍了怎样在maven中使用webtest插件实现web的集成測试,这里有个遗留 ...
- Etcd学习(一)安装和.NETclient測试
Etcd是一个比較新的分布式协调框架,由CoreOS的开发团队开发,如今才仅仅到0.4.6版本号,还没公布1.0版本号 我看了一下GitHub上作者们的提交记录,如今应该还在如火如荼的开发以及改动Bu ...
- Android单元測试之JUnit
随着近期几年測试方面的工作慢慢火热起来.常常看见有招聘測试project师的招聘信息.在Java中有单元測试这么一个JUnit 方式,Android眼下主要编写的语言是Java,所以在Android开 ...
- 从linux telnet到exchange邮件server来測试发送邮件
我们在Linux下,能够通过telnet邮件server的25port(一般smtp邮件server都是这个),来測试是否能发送邮件. 前提是先得把DNS配好,或者/etc/hosts文件制定好邮件s ...
- Coreseek:第二步建索引及測试
1,建索引非常easy.一行代码 g:/service/coreseek/bin/indexer -c g:/service/coreseek/etc/csft_mysql.conf person ...
- Android 进行单元測试难在哪-part3
原文链接 : HOW TO MAKE OUR ANDROID APPS UNIT TESTABLE (PT. 1) 原文作者 : Matthew Dupree 译文出自 : 开发技术前线 www.de ...
随机推荐
- Mustache模板引擎
Mustache是一个Logic-Less模板引擎,即:零逻辑引擎,原因在于它只有标签,没有流程控制语句,这是它与其它模板引擎不同的地方. Mustache小巧玲珑,几乎用各种语言都实现了一遍. Mu ...
- 一个Linux下C线程池的实现
什么时候需要创建线程池呢?简单的说,如果一个应用需要频繁的创建和销毁线程,而任务执行的时间又非常短,这样线程创建和销毁的带来的开销就不容忽视,这时也是线程池该出场的机会了.如果线程创建和销毁时间相比任 ...
- java socket输入输出中文乱码问题
http://hi.baidu.com/linjk03/item/e2028bfd990c14ea1a111feb 统一了输入输出的编码格式,是不会有乱码问题出现的. 构造Reader或Write ...
- Android开发学习之对话框浅析
对话框式程序运行中弹出的窗口.Android系统中有四种默认的对话框:警告对话框AlertDialog.进度对话框ProgressDialog.日期选择对话框DatePickerDialog以及时间选 ...
- 定制WinEdt 优化Latex输入
定制WinEdt 优化Latex输入 ---原文转载地址:http://www.mamicode.com/info-detail-342716.html ---推荐winedt功能定制使用-说明文档: ...
- 不停mysql服务添加从库的两种方式
现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库.前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作. ...
- asp.net用三层实现多条件检索
众所周知,三层将项目分为界面层,业务逻辑层和数据訪问层(以最主要的三层为例) 相同都知道,多条件检索事实上就是依据用户选择的条件项,然后来拼sql语句 那么.既然要依据用户选择的条件项来拼sql语句, ...
- Java 如何实现线程间通信
正常情况下,每个子线程完成各自的任务就可以结束了.不过有的时候,我们希望多个线程协同工作来完成某个任务,这时就涉及到了线程间通信了. 本文涉及到的知识点: thread.join(), object. ...
- 李洪强iOS之集成极光推送二iOS 证书 设置指南
李洪强iOS之集成极光推送二iOS 证书 设置指南 创建应用程序ID 登陆 iOS Dev Center 选择进入iOS Provisioning Portal. 在 iOS Provisioning ...
- 通过命令来查看NameNode的状态(是Active还是Standby)
通过浏览器虽然可以查看HDFS的NameNode的状态,如果感觉不方便,可以直接使用命令来查看(前提是HDFS已经启动): [root@hadoop01 ~]# hdfs haadmin -getSe ...