zoukankan      html  css  js  c++  java
  • iOS 通知观察者的被调函数不一定运行在主线程

    iOS 通知观察者的被调函数不一定运行在主线程

    今天修复Bug时候发现的一个小细节,记录下。

    问题描述

    事情是这样的:我在A视图(UITableView)注册了一个通知,当接收到此通知时,就重新读取数据并调用[tableView reloadData]。但是视图有时刷新后的显示的内容不对,再重新切换下视图又正常了。

    代码如下:

    分析 & 解决

    经过一番调试,在被调函数reloadFavDBData打了断点后意外发现,它并不是在主线程运行的!而我们在这里做了与UI相关的[tableView reloadData]操作——在非主线程做UI刷新操作,导致了显示异常的问题。

    解决办法也很简单,在被调函数中切换到主线程再做操作就行啦。

    WHY?

    测试得来的结论还是不够完整。翻了翻官方文档,在NSNotificationCenter部分看到这样一段话:

    In a multithreaded application, notifications are always delivered in the thread in which the notification was posted, which may not be the same thread in which an observer registered itself.

    在多线程程序中,通知总是在发送通知者的线程中调用(delivered,可以这么理解么?),结合上述所遇到的情况,我的理解是,通知观察者的被调函数总是运行在发送通知者的线程中,如下图所示:

    Notification_thread

    这个结论告诉我们,通知的被调函数不一定运行在主线程中,如果需要做UI相关操作,需要手动切换到主线程。

    有空再尝试看看通知的实现原理,应该会有更透彻的理解。

  • 相关阅读:
    小程序中上传图片并进行压缩
    vue在传值的时候经常遇到的问题
    【H5】移动开发 rem
    【入门】Less 知识点整理
    【入门】前后端交互
    原型对象、原型链
    跨域-jsonp、cors、iframe、document.domain、postMessage()
    css水平垂直居中
    localStorage、sessionStorage、cookie、session
    vue中父组件调用子组件函数
  • 原文地址:https://www.cnblogs.com/itlover2013/p/4324666.html
Copyright © 2011-2022 走看看