gpt4 book ai didi

haskell - Haskell 中的并行性

转载 作者:行者123 更新时间:2023-12-04 21:17:30 26 4
gpt4 key购买 nike

我正在尝试创建一个进行并行评估的简单示例:

import Control.Parallel.Strategies

main = do
runEval $ do
a <- rpar (\x -> x + 5)
b <- rseq (\x -> x + 15)
return (a, b)

它说
Couldn't match expected type `IO t0'
with actual type `(Integer -> Integer, Integer -> Integer)'

我知道,它与 Haskell 中的并行性无关,但是,我如何在 Haskell 中构建这样一个简单的示例?

最佳答案

问题在于您使用 lambda 的方式。 rpar的种类和 rseqa -> Eval a但是您传递的 lambdas 显然类型为 Integer -> Integer因为您没有将参数传递给 lambda。

像这样编译(另请注意,您需要打印结果):

main = do
print $ runEval $ do
a <- rpar $ (\x -> x + 5) 4
b <- rseq $ (\x -> x + 15) 4
return (a, b)

了解有关 Haskell 中并行处理的更多信息。有一本很棒的书叫 "Parallel and Concurrent Programming in Haskell"作者 Simon Marlow,HTML 版本可免费获得 here :

关于haskell - Haskell 中的并行性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19582586/

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