- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
Visual Studio 的恐惧“将其他线程拒之门外”。还有一个替代版本 _fread_nolock,它的意思是“不锁定其他线程”,它应该只在“线程安全的上下文中使用,例如单线程应用程序或调用范围已经处理线程隔离的地方。”
即使在阅读了关于这两者的其他一些相关讨论之后,如果锁定 fread 实现是在特定的 FILE 结构、特定的实际文件上,还是在对完全不同的文件的所有 fread 调用上,我仍然感到困惑。
如果您使用 nolock 版本,您需要提供什么级别的锁定?多个线程可以在没有任何锁定的情况下并行读取单独的文件吗?多个线程可以在没有任何锁定的情况下并行写入单独的文件吗?或者是否涉及会损坏的全局或静态变量?
因此,通过使用 nolock 版本,您是否能够潜在地实现更好的 I/O 吞吐量(如果您没有不必要地移动磁头,例如读取单独的驱动器或 SSD 驱动器),或者潜在的 yield 只是将冗余锁减少为单个锁(这应该可以忽略不计。)
VS 的 ifstream.read 函数是否像常规 fread 一样工作? (我没有看到它的无锁版本。)
最佳答案
MS 标准库实现完全支持多线程。 C++ 标准解释了这个要求:
27.2.3: Concurrent access to a stream object, stream buffer object, or C Library stream by multiple threads may result in a data race unless otherwise specified.
If one thread makes a library call a that writes a value to a stream and, as a result, another thread reads this value from the stream through a library call b such that this does not result in a data race, then a’s write synchronizes with b’s read.
这意味着,如果您在流上写入,则会完成锁定(不是文件锁定,而是对内存中流数据结构的并发访问锁定),以确保所有其他线程的并发性得到很好的管理同一个流。
这种锁定开销始终存在,即使不需要。根据微软的说法,这可能有一个性能方面的问题:
the performance of the multithreaded libraries has been improved and is close to the performance of the now-eliminated single-threaded libraries. For those situations when even higher performance is required, there are several new features.
这就是提供 _nolock 函数的原因。他们直接访问流而无需线程锁定。必须格外小心地使用它,例如:
在这种情况下,不需要/多余的用于流访问的额外锁。对于文件密集型功能,可能值得使用 no_lock。
注意:正如您所指出的:只有在您进行数百万次访问的密集文件访问中才值得使用 nolock。
关于c++ - fread 线程锁处于什么级别?他们需要达到什么水平?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29870879/
我是一名优秀的程序员,十分优秀!