android单元测试中的多线程以及handler消息传递

 在android的单元测试中,因为涉及到了其他函数的层层调用,涉及到多线程,结果出现以下问题。

1)在主线程之外的其他线程中设置断点,但是毫无效果,因为转化为利用日志log.v()的方式进行调试。

2)结果发现,在多个地方log.v的时候,会出现每次打印的日志信息条数不同的情况,而且不能将所有的日志信息打印完全。

3)考虑可能是一旦主线程运行结束,单元测试便完结所导致,因此主线程之外的线程中的有些log.v来不及打印,在单元测试的主线程中令线程休眠一段时间Thread.sleep(1000),发现上面一个问题得到解决。

4)另一方面,测试的模块中具有利用handler进行消息传递的机制,发现即使令主线程休眠,handler对象的回调函数handlemessage依旧得不到执行。

总结,由此可见,android单元测试最好还是用来处理功能单一的函数,当涉及测试某个模块的整体功能时候,因为复杂的函数调用,尤其是包含消息传递机制或者多线程的时候,最好还是编写一个样例来测试整个流程。

 

 

转载于:https://www.cnblogs.com/bobodeboke/archive/2012/12/16/2820409.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值