gpt4 book ai didi

multithreading - TCriticalSection 有很多读者和一个作者

转载 作者:行者123 更新时间:2023-12-03 18:17:57 27 4
gpt4 key购买 nike

我有一个用 Delphi 10 Seattle Win32 编写的服务应用程序,它具有在线程中定期更新的内存数据。

由于数据是一个复杂的结构并且以 block 的形式接收,更新代码写入一个临时列表,当它完成结构时将这个临时列表切换到一个“生产”列表,由许多读取线程读取。

我将“switch”代码与各自的读者放在一起作为关键部分,以使它们相互排除。后来我意识到,读者线程之间的副作用也是相互排斥的。

我的问题是是否有一个替代的关键部分类,我可以将其描述为读者或作者,以便允许读者同时执行。

除此之外,我只保护读取器代码,该代码收集必须发送的数据并在离开临界区后复制要发送的数据。我想知道让这个数据收集代码互斥或序列化是否应该更高效。

提前致谢。

最佳答案

TMultiReadExclusiveWriteSynchronizer在 SysUtils 中。 (如果您喜欢手指,请考虑使用来自同一单元的 TMREWSync 别名。)

不过请记住,它非常慢,而且很多时候一个简单的关键部分会表现得更好。

在为 Windows 编译时,您还可以考虑使用 Slim Reader/Writer .那个是特定于 Windows 的,但速度非常快。

关于multithreading - TCriticalSection 有很多读者和一个作者,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53173996/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com