有人了解HASKELL的Software Transacational Memory吗?

发布于 2022-08-16 08:10:05 字数 850 浏览 11 评论 2

请教两个问题:
1、Haskell中的事务允许包含IO吗?
2、如果事务允许包含IO的化,那么Haskell是怎么实现IO回滚的?

请用Haskell的STM完成下面的功能,先谢谢了。

  1. // 使用io_mutex保证thread1、thread2的输出行不会交织在一起。
  2. pthread_mutex_t io_mutex;
  3. void thread1()
  4. {
  5.        pthread_mutex_lock(&io_mutex);
  6.        printf("THREAD1 OUTPUTn");
  7.        pthread_mutex_unlock(&io_mutex);
  8. }
  9. void thread2()
  10. {
  11.        pthread_mutex_lock(&io_mutex);
  12.        printf("THREAD2 OUTPUTn");
  13.        pthread_mutex_unlock(&io_mutex);
  14. }

复制代码
[ 本帖最后由 CRLF 于 2009-2-9 21:13 编辑 ]

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

两人的回忆 2022-08-19 07:21:36

先谢2L解答!

第一次看到STM的介绍时,觉得STM真是个好主意,应该能够解决多线程中复杂的LOCK问题,但是后来深入了解后才发现STM有个非常棘手的问题,就是很难实现高效的、透明的IO回滚,有的论文提出使用BUFFER的方式可以实现在STM中包含IO,可惜只是paper design,当不得真的。

INTEL的C++ STM原型编译器已经出第3版了,初看它的例子,真的很吸引人,只要用__tm_atomic把需要原子执行的代码块标记出来就可以了,但是看了下它的手册,发现在实际中使用STM并不是像paper中描述的那么美好和简单。

附录:INTEL的C++ STM编译器
http://software.intel.com/en-us/ ... ototype-edition-20/

瞳孔里扚悲伤 2022-08-16 14:24:47

事务当中当然不能包括 IO,否则就有你说的回滚的问题。
你说的问题,用 STM 可以这样解决:

  1. data FlwMutex = FlwMutex (TVar Int)
  2. flwMutexLock                    :: FlwMutex -> IO ()
  3. flwMutexLock (FlwMutex tv)   = atomically $ do
  4.     n <- readTVar tv
  5.     check (n == 0)
  6.     writeTVar tv 1
  7.     return ()
  8. flwMutexUnlock                 :: FlwMutex -> IO ()
  9. flwMutexUnlock (FlwMutex tv) = atomically $ do
  10.     n <- readTVar tv
  11.     check (n == 1)
  12.     writeTVar tv 0
  13.     return ()
  14. thread1         :: FlwMutex -> IO ()
  15. thread1 mutex   = do
  16.     flwMutexLock mutex
  17.     putStrLn "--- Thread1 output ---"
  18.     flwMutexUnlock mutex
  19. thread2         :: FlwMutex -> IO ()
  20. thread2 mutex   = do
  21.     flwMutexLock mutex
  22.     putStrLn "--- Thread2 output ---"
  23.     flwMutexUnlock mutex

复制代码
当然了,不排除有已经包装好的 POSIX pthread API,我就不清楚了。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文