我正在检查英特尔的"whatif"网站及其事务内存编译器(每个线程必须进行原子提交或回滚系统的内存,就像数据库一样).
这似乎是替换锁和互斥锁的一种有前途的方法,但我找不到很多推荐.这里有人有任何意见吗?
我没有使用英特尔的编译器,但Herb Sutter对此有一些有趣的评论......
来自Sutter讲话:并发的未来
您是否对事务内存有很多兴趣和使用,或者大多数开发人员难以理解这个概念?
目前还不能回答谁在使用它,因为它还没有上市.英特尔有一个软件事务内存编译器原型.但如果问题是"开发人员难以使用吗?" 答案是我当然希望不会.重点是它比锁更容易.这是研究领域唯一的主要内容,它希望大大减少我们对锁的使用.它永远不会完全取代锁,但是我们唯一的希望是部分更换它们.
有一些限制.特别是,一些I/O是本身不支持事务,你不能把一个原子块提示用户输入他的名字,并从控制台读取的名称,只是自动中止并重试块,如果它与其他事务冲突; 如果你提示他两次,用户可以分辨出差异.但是,事务性内存非常适合仅触及内存的内容.
我所知道的每个主要硬件和软件供应商在研发方面都有多个事务存储工具.有关于基本问题的理论答案的会议和学术论文.我们还没有进入Model T阶段,我们可以将它发布出去.你可能会看到早期,原型有限的,你不能做无界事务内存,在那里你可以只读取和写入,也就是说,100个存储位置.但是,这对于启用更多无锁算法仍然非常有用.