- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在寻找 Composable operations - 使用事务内存很容易做到。 (感谢 Ami Tavory)
使用锁(互斥锁/自旋锁)很容易做到 - 但它可能导致死锁 - 因此基于锁的算法只能通过手动调整组合。
无锁算法不存在死锁问题,但不可组合。需要将 2 个或更多容器设计为单个组合的无锁数据结构。
是否有任何方法、辅助实现或一些无锁算法 - 原子地与多个无锁容器一起工作以保持一致性?
...
或者 RCU 或危险指示器可以帮助做到这一点吗?
众所周知,我们可以使用无锁容器,这在其实现中很困难,例如并发数据结构(CDS)库:http://libcds.sourceforge.net/doc/cds-api/group__cds__nonintrusive__map.html
例如,我们可以使用无锁有序映射,如SkipList CDS-lib
但即使是简单的无锁算法在任何情况下都不是无锁的:
You may iterate over skip-list set items only under RCU lock. Only in this case the iterator is thread-safe since while RCU is locked any set's item cannot be reclaimed. The requirement of RCU lock during iterating means that deletion of the elements (i.e. erase) is not possible.
::contains(K const &key)
- documentation-link The function applies RCU lock internally.
::get(K const &key)
并更新我们得到的元素,我们应该使用锁:documentation-link 例子:
typedef cds::container::SkipListMap< cds::urcu::gc< cds::urcu::general_buffered<> >, int, foo, my_traits > skip_list;
skip_list theList;
// ...
typename skip_list::raw_ptr pVal;
{
// Lock RCU
skip_list::rcu_lock lock;
pVal = theList.get( 5 );
if ( pVal ) {
// Deal with pVal
//...
}
}
// You can manually release pVal after RCU-locked section
pVal.release();
但是如果我们使用 2 个无锁容器而不是 1 个,并且如果我们只使用总是无锁的方法,或者其中一个是无锁的,那么我们可以在不锁定两个容器的情况下做到这一点吗?
typedef cds::urcu::gc< cds::urcu::general_buffered<> > rcu_gpb;
cds::container::SkipListMap< rcu_gpb, int, int > map_1;
cds::container::SkipListMap< rcu_gpb, int, int > map_2;
我们能否自动将 1 个元素从 map_1
移动到 map_2
而不锁定两个容器 - 即 map_1.erase(K const &key)
和 map_2.insert(K const &key, V const &val)
如果我们想保持原子性和一致性:
其他线程看不到第一个容器里没有元素,而他在第二个容器里还没有出现
其他线程看不到第一个容器中有元素,而第二个容器中已经有相同的元素
如果我们想保持原子性和一致性,我们能否在不锁定两个或多个无锁容器的情况下以原子方式执行某些操作?
回答:我们不能通过简单地使用其通常的功能,在没有锁的情况下同时对两个或多个无锁容器执行任何原子操作。
只有当我们在容器 API 中执行 1 个无锁算法提供的简单操作时,对于 2 个无锁容器,1 个锁就足够了,排除上述 3 种情况,即使在无锁容器中也使用锁。
此外,如果您对无锁算法进行了复杂的自定义改进,那么“但可能会有一些额外的开销”,那么您可以提供一些可组合的,例如,因为“两个队列彼此了解,并且代码看起来正如 Peter Cordes 指出的那样,它们是经过精心设计的。
最佳答案
TL:DR:正如 Yakk 指出的那样,您的要求没有多大意义。但是,由于您只要求一种无需锁定两个 容器即可完成此操作的方法,因此您可以执行以下操作。如果这不是您要查找的内容,那么也许这将有助于说明您提出问题的方式存在的问题之一。
A multiple-readers / single-writer lock在一个容器上可以轻松实现,并解决观察两个容器的问题。
但是,对您锁定的容器的无锁访问是永远不允许的,因此使用无锁容器毫无意义。
如果在观察无锁容器时在锁定容器上持有读锁,那么在观察无锁容器时,关于锁定容器的任何知识仍然为真。
在锁定容器上设置写锁会阻止任何读者在您删除元素时观察锁定的数据结构。所以你会使用像这样的算法:
write_lock(A); // exclude readers from A
tmp = pop(A);
push(B, tmp);
write_unlock(A); // allow readers to observe A again, after both ops are done
在另一个方向上移动节点的工作方式相同:在锁定容器上持有写锁的同时执行删除和添加操作。
您可以通过暂时将元素放在两个容器中来节省复制,而不是暂时放在两个容器中(复制到临时容器中)。
write_lock(A); // exclude readers from A
B.add(A[i]); // copy directly from A to B
A.remove(i);
write_unlock(A); // allow readers to observe A again, after both ops are done
我并不是说没有无锁的方法可以做到这一点,顺便说一句。 @Ami 指出事务内存可以支持 synchronization composability .
但是您的规范的主要问题是不清楚您到底想阻止潜在的观察者观察什么,因为他们只能按一个顺序观察两个无锁数据结构或另一个,不是原子的,正如@Yakk 指出的那样。
如果您控制观察者进行观察的顺序,以及作者进行写作的顺序,这可能就是您所需要的。
如果您需要在两个容器之间建立更强的链接,则可能必须将它们设计为了解两个容器的单个无锁数据结构。
关于c++ - 我们可以用 2 个或更多无锁容器原子地做一些事情而不锁定两者吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38894978/
我正在开发一个带选项卡栏的 ios 应用程序。我的栏上有超过 5 个按钮,所以在 iphone 上我有更多的按钮。现在,假设我有这个按钮:Button1 Button2 Button3 Button4
我有一个带有 UITabBarController 的应用,其中有超过五个选项卡。 当我按更多选项卡时,我会转到moreNavigationController,它是一个UINavigationCon
我有一个导航 Controller 。 NAVC->MORE... 按钮,然后在“更多”下有一些额外的 VC。 如果我转到“更多...”下的 VC,然后转到不在“更多...”上的 VC,那么当我返回到
因此,我想出了这种方案,用于在多个线程同时具有读写访问权限的二叉树中旋转时锁定节点,这涉及每次旋转锁定四个节点,这似乎是一个很多吗?我想到了一种比我想出的方法更聪明的方法来减少所需的锁定,但谷歌并没有
所以我已经尝试了所有方法,但我似乎仍然无法将下拉内容与 dropbtn 对齐。我只希望内容始终位于更多菜单下方。 HTML: `
我正在尝试使用 expect 来自动接受在 --more-- 中提示的 EULA。 #!/usr/bin/expect spawn "./greenplum-perfmon-web-4.1.2.0-b
他们如何在下面提供的网站上制作“告诉我更多”效果。我读过 read more/less effect in jQuery,但我发现该站点的有趣之处在于,除非单击该按钮,否则无法滚动页面。 Effect
现在,Kim Stebel helped me understanding如何使用存在类型键入变量,我需要知道如何在继承中使用它们: 以下代码无法编译: class PagingListModel(s
在我的Cygwin中不可用。另一方面,提供了“ less”命令。也许Cygwin的制造商认为“更多”只是多余的。 我对此很好奇。 最佳答案 安装util-linux软件包,您将获得“更多”的信息 ht
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我们使用 asp.net mvc、javascript 和 jQuery(托管在本地计算机上)创建了一个应用程序。基本设计是,当用户从一个页面导航到其他页面时,我们通过隐藏和显示 HTML 页面,将所
我想用 RMonad 做一些基本的事情。有没有办法使用“as monad”功能来 有一个身份 rmonad,可以应用 monad 转换器吗? 有诸如 StateT 变压器之类的常见东西吗? 向现有 m
我有一个 char*[] 数组。我需要能够为其分配字符串并再次删除它们,但我不知道: 如何检查一个元素中是否已经有一个字符串,这样我就不会覆盖它,如果它已经被占用,则继续处理下一个元素? 之后如何将其
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我有一个程序可以同时吐出标准错误和标准输出,我想在标准错误上少运行寻呼机,但忽略标准输出。我该怎么做? 更新: 就是这样......我不想丢失标准输出......只是让它远离寻呼机 program 2
基本上,当单击具有类 "dropdown" 的链接时,我无法获取“更多...”链接来对下一个跨度的高度进行动画处理。它根本就没有动画。仅当更改为 Less... 链接并且单击 Less... 链接以折
我正在使用 ExtJS,并认为它是一个了不起的框架。但是,它们没有内置的状态图,这使得依赖于状态的应用程序开发非常痛苦。 我最近发现了这个: https://github.com/jakesgordo
我一直在研究数据结构和算法,遗憾的是在C中。我已经单独实现了一个双向链表,它保存整数并且工作正常,但是当节点(或pub)让它正常工作时我遇到了很多麻烦在本例中)保存多个不同类型的值。我可以创建一个列表
编辑拼写错误 你好, 这可能是一个愚蠢的问题,但如果它能帮助我遵循最佳实践,我不在乎:P 假设我想在 System.Data 命名空间...以及 System.Data.SqlClient 命名空间中
使用 bootstrap 3 CSS、font awesome CSS 和最新的 jQuery JS 文件。 我正在使用 javascript 在单击按钮时在另一个内容 div 之上隐藏/显示一个内容
我是一名优秀的程序员,十分优秀!