10、高效并发对象实现与多核架构性能分析

高效并发对象实现与多核架构性能分析

并发对象的高效实现

在并发编程中,实现高效的并发对象是一个重要的目标。这里我们主要探讨一种可线性化的无阻塞栈以及一种对竞争敏感的无饥饿栈的实现。

无阻塞栈操作

无阻塞栈提供了两个基本操作: non blocking push(v) non blocking pop() 。其代码如下:

operation non blocking push(v):
repeat res ←weak push(v) until res ̸= ⊥end repeat;
return(res).

operation non blocking pop():
repeat res ←weak pop() until res ̸= ⊥end repeat;
return(res).

这两个操作通过不断尝试执行 weak push(v) weak pop() 操作,直到返回非 值,从而实现无阻塞的栈操作。

对竞争敏感的栈实现

目标是设计一种对竞争敏感的无饥饿栈,该算法在无竞争时仅执行少量且有常数界的共享内存访问,仅在有竞争时使用锁。

  • 数据结构
    • LOCK :一个锁,通过 lock() </
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值