• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - 将 InvokeOnMainThread 嵌套在锁内,反之亦然

[复制链接]
菜鸟教程小白 发表于 2022-12-12 21:09:47 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

将其中一个嵌套在另一个中是否不好?过去,我有一个挂起/死锁问题,在执行顶部代码块时我可以重现,而当我将其更改为底部代码块时我无法重现......我真的不明白时间,我仍然没有。关于 Lock 和 InvokeOnMainThread 的组合有什么我应该知道的吗?我可以提供更多关于我在做什么的细节,但这更像是一个普遍的问题......

假设我想在后台线程中“DoStuff”。我有一个可以从多个线程访问的变量。

lock( stuff )
{
    InvokeOnMainThread ( delegate {
        stuff.DoStuff();
    });
}

替代

InvokeOnMainThread ( delegate {
    lock( stuff )
    {
        stuff.DoStuff();
    }
});

添加信息:我有一个带有连接管理器功能的 iOS 应用程序,该功能在后台线程中运行。连接管理器功能负责保持事件和管理异步网络套接字连接。在很多情况下,我需要在执行操作时调用 InvokeOnMainThread,否则我会收到以下错误“UIKit 一致性错误:您正在调用只能从 UI 线程调用的 UIKit 方法。”



Best Answer-推荐答案


两者之间的区别在于,第二个代码块不会阻止在执行 DoStuff 之前在执行线程上执行任何操作。

例子:

 lock (stuff) {
     InvokeOnMainThread ( delegate { Console.WriteLine ("a"); } }
 }
 Console.WriteLine ("b");

将打印:

a
b

这段代码:

 InvokeOnMainThread ( delegate {
    lock (stuff) {
        Console.WriteLine ("a");
    }
 }
 Console.WriteLine ("b");

通常(但不一定)会打印:

b
a

现在这并不能解释为什么第二个 block 会修复竞态条件,但我的猜测是它只会改变竞态条件,足以让你不再击中它(所以不要修复它,只是隐藏它) .

关于ios - 将 InvokeOnMainThread 嵌套在锁内,反之亦然,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22768212/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap