OCaml的并行化能力是什么状态?

And*_*ott 40 parallel-processing ocaml

我有兴趣将OCaml用于项目,但是我不确定它的并行化功能在哪里.OCaml中是否有消息传递功能?OCaml能否有效地使用1个以上的CPU?

我读到的关于这个主题的大部分内容是在2002 - 2006年写的,我最近没有看到任何东西.

谢谢!

hui*_*ker 23

2009年发行Caml每周新闻("CWN",来自caml列表的有趣消息的摘要)表明:

还有:

  • Netmulticore - 通过映射共享内存共享ocaml值的多处理.

  • CamlP3l - Caml并行程序的编译器.

  • OCaml-Java - 一个发出Java字节码的OCaml编译器


不过,我没有关注Ocaml和并行编程的最新讨论.我要离开这个CW,以便其他人可以更新我提到的内容.如果这个问题可以达到与Haskell类似的完整性,那将是很好的.


Mic*_*and 8

目前,OCaml运行时不支持并行运行多个内核,因此单个OCaml进程无法利用多个内核.这不太可能直接改变; OCaml开发人员最感兴趣的方向是增加并行性,这似乎允许多个OCaml运行时在一个进程中并行运行; 这将允许非常快速的消息传递,但不允许多个线程在共享内存配置中并行运行.主要的垃圾是垃圾收集器; 几年前,该团队尝试了并发GC,但它在单线程案例中引入了不可接受的减速.

有几个项目,即FunctoryOCamlnet,它们通过使用多个进程提供多核幸福的并行性.

通常,OCaml社区倾向于支持消息传递方法,这可以通过单进程共享内存多线程跨进程边界(如OCamlnet)来完成.如果您的程序可以分成多个进程(很多可以!),那么是的,您可以有效地使用多个CPU.