multithreading - Haskell:TMVar 与 MVar

标签 multithreading haskell concurrency stm

我想要一个小操作,其中一个线程向共享状态添加一些值,而另一个线程取出该值并打印它。这是分别使用 TMVar 和 MVar 的两个版本。 TMVar 版本无法正常工作,它不断打印第一个值。 STM第一版有什么问题?如何修复第一个 TMVar 版本以使其正常工作?

import Control.Concurrent (forkIO, takeMVar,newEmptyMVar,putMVar)
import Control.Monad (forM_, replicateM_)
import Control.Concurrent.STM (atomically, readTMVar, putTMVar, newEmptyTMVarIO)

n=10

main = do

    mvar<- newEmptyTMVarIO

    forkIO $ do
        forM_ [1..n] $ \x-> atomically $ do
            putTMVar mvar $! x

    replicateM_  n $ do
        a<- atomically $ readTMVar mvar
        print $ show a


main2 = do

    mvar<- newEmptyMVar

    forkIO $ do
        mapM_ (\x-> putMVar mvar x) [1..n]

    replicateM_  n $ do
        a<- takeMVar mvar
        print $ show a

最佳答案

您正在使用 readTMVar,它仅查看 TMVar 中的内容。我想您的意思是使用 takeTMVar 让另一个线程有机会在其中添加新内容。

关于multithreading - Haskell:TMVar 与 MVar,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63716645/

相关文章:

haskell - 使用 GHC 编译非常大的常量

haskell - 为 Haskell Platform(标准库)生成 ctag,专门用于 prelude

Java套接字 - 客户端不从服务器的套接字读取字符串

java - 从另一个类访问的单例类

java - 信号量公平参数不遵循先进先出

c++ - 使用 x86 汇编的信号量实现

java - 哈希表中的并发性和故障安全行为

c - 套接字被 pause() 阻塞

haskell - 在 Haskell 中求解 Euler #31

Python:WAITING所有 `concurrent.futures.ThreadPoolExecutor` 的 future