gpt4 book ai didi

ocaml - 使用 ocaml 和 jane street async 的可变数据

转载 作者:行者123 更新时间:2023-12-02 21:20:55 26 4
gpt4 key购买 nike

我正在 OCaml 中使用 Jane Street 的异步库进行并发处理一个项目。我想让多个 TCP 服务器接受输入,它们的处理程序操纵单个哈希表(Hashtbl.t)。似乎这种情况需要我使用互斥体(Mutex.t 的)来保护我的哈希表。

但是,当我阅读异步文档和 Real World Ocaml 中有关异步的章节时,我的印象是存在一个使用 Deferred.tPipe.t,以及使用线程和互斥体的“系统线程世界”,混合它们的唯一方法是使用 Thread_safe 模块,所以我不太愿意将互斥量放入我的异步计算中。

那么基本上,在异步进行并发计算时,我应该如何保护共享的可变数据结构?

最佳答案

一般来说,如果某些操作可以原子执行,则不需要使用互斥锁来保护它。但这句话根据上下文有不同的含义。

在异步上下文中,原子操作最严格的定义是没有类型'a Deferred.t 的操作。换句话说,如果它没有被延迟,那么它就是原子的,在它执行的过程中,它不能被任何其他线程打断。事实上,由于 async 库实现了协作线程,您总是知道给定的函数是否可以被中断,这与抢占式线程不同。

这意味着,您可以使用任何 OCaml 模块,当然包括哈希表,无需任何互斥锁,因为它们的所有操作都是原子的。

协作式多线程实际上很少需要互斥量。通常,实现交易行为。

关于ocaml - 使用 ocaml 和 jane street async 的可变数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27784389/

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