handler笔记(sendXX、postXX、延迟处理)

关于handler的post、延迟消息这2个点有点忘记了。这两天重看了下handler源码,学习笔记总结下

之前写过一篇,handler源码分析

这里只说下架 post、延迟消息。

测试代码很简单:(Kotlin)

    private var mHandler = object : Handler() {

        override fun handleMessage(msg: Message?) {
            super.handleMessage(msg)

            Log.e("收到消息 ${msg?.what}","时间:${System.currentTimeMillis()}")
        }
    }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        mHandler.sendEmptyMessage(1)

        mHandler.sendEmptyMessageDelayed(2,5*1000)

        mHandler.post(Runnable(){

            Log.e("handler","post 线程:${Thread.currentThread()}")

        })

        mHandler.postDelayed({

            Log.e("handler","postDelayed 线程:${Thread.currentThread()}")

        },10*1000)

    }

对应日志:

2021-04-06 09:15:07.237 E/收到消息 1: 时间:1617671707237
2021-04-06 09:15:07.237 E/handler: post 线程:Thread[main,5,main]

2021-04-06 09:15:12.204 E/收到消息 2: 时间:1617671712204
2021-04-06 09:15:17.204 E/handler: postDelayed 线程:Thread[main,5,main]

结论:
1、利用post发消息,可以直接跟回调处理代码
2、post完成后,处理代码的是主线程

postXX方法,最后也会都走到 sendMessageAtTime

引申个问题,handler 是怎么保证,延迟操作的正确性的?或者说,如果我指定了90秒后打印一句话,在90面之内

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值