有人了解HASKELL的Software Transacational Memory吗?
请教两个问题:
1、Haskell中的事务允许包含IO吗?
2、如果事务允许包含IO的化,那么Haskell是怎么实现IO回滚的?
请用Haskell的STM完成下面的功能,先谢谢了。
- // 使用io_mutex保证thread1、thread2的输出行不会交织在一起。
- pthread_mutex_t io_mutex;
- void thread1()
- {
- pthread_mutex_lock(&io_mutex);
- printf("THREAD1 OUTPUTn");
- pthread_mutex_unlock(&io_mutex);
- }
- void thread2()
- {
- pthread_mutex_lock(&io_mutex);
- printf("THREAD2 OUTPUTn");
- pthread_mutex_unlock(&io_mutex);
- }
复制代码
[ 本帖最后由 CRLF 于 2009-2-9 21:13 编辑 ]
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
先谢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/
事务当中当然不能包括 IO,否则就有你说的回滚的问题。
你说的问题,用 STM 可以这样解决:
复制代码
当然了,不排除有已经包装好的 POSIX pthread API,我就不清楚了。