免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3347 | 回复: 0
打印 上一主题 下一主题

有人了解HASKELL的Software Transacational Memory吗? [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
1 [报告]
发表于 2009-02-10 10:52 |显示全部楼层
事务当中当然不能包括 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,我就不清楚了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP