社区
进程/线程/DLL
帖子详情
休息时间,来做点有点难度思考题
阿呆_
2008-10-24 01:11:56
1、多线程不加锁对单链表安全地插入/删除节点(包括修改头指针)。
2、多线程不加锁对双链表安全地插入/删除节点(包括修改头、尾指针)。
可能吗? 如何实现?
...全文
241
23
打赏
收藏
休息时间,来做点有点难度思考题
1、多线程不加锁对单链表安全地插入/删除节点(包括修改头指针)。 2、多线程不加锁对双链表安全地插入/删除节点(包括修改头、尾指针)。 可能吗? 如何实现?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
23 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
caitian6
2008-10-27
打赏
举报
回复
不加锁 又要实现 防止读 脏数据。。。。。。
无语
lygfqy
2008-10-27
打赏
举报
回复
感觉如果不对存储空间进行保护,任何同步的操作都会对程序产生极大的危害
如果仅仅是考虑锁的锁定问题最好还是那里出问题那里解决
单纯从题目的表现内容来看
也许可以通过一个副本的方式来解决这个问题
但是复杂度可能会更加大了
保留时间段的链表副本
记录各个时间段中的添加和删除的步骤
利用其他的时间定时模式来生成下一个时间段的副本
或者在需要读取数据的操作到来时生成副本
这样就避免了实时操作数据产生的冲突
上述想法仅仅是停留于思考而并未实施实现
ok1234567
2008-10-27
打赏
举报
回复
::WaitForSingleObject之类的应该比较简明、好控制
自己搞个粒度锁什么的可用于长期的探索,但是可靠性及性能都可能与设计有较大偏差
sanshao27
2008-10-27
打赏
举报
回复
mark
cppwin
2008-10-27
打赏
举报
回复
如果出现了cpu 100%的情况,说明这种情况完全不适合用Interlockedxxx方案.
使用sleep表面降低了cpu 使用率, 但它实际上在一个while循环里无数次用sleep切换context,其效率比使用CriticalSection差了无数倍,因为CriticalSection只切换一次(一个来回).
另外你的代码用多次的InterlockedExchange()来操作,坦率说,是错的.
WinEggDrop
2008-10-27
打赏
举报
回复
[Quote=引用 14 楼 cppwin 的回复:]
要点在于用 InterlockedCompareExchange(), 来保证 从比较到修改 是原子操作.
Enter时:
while( InterlockedCompareExchange( &m_nLock, 1, 0 ) ==0 ) {}
一般不用sleep, 因为sleep也一样导致线程切换.
如果你觉得你的具体情况需要使用sleep,考虑一下,使用信号量是不是更好.
使用Interlocked系列函数,要考虑具体环境,
它锁住系统数据总线,如果电脑cpu数较多,会引发频繁碰撞,效率反而低了.
在早期的单cpu电脑中,…
[/Quote]
不sleep()的话,多线程这样执行,系统CPU马上100%使用率.
cdef9108
2008-10-25
打赏
举报
回复
同步应该是要必须立刻进行的,
野男孩
2008-10-24
打赏
举报
回复
无聊
kingcrab
2008-10-24
打赏
举报
回复
什么叫不叫锁?Interlockedxxx 本身就叫互锁函数。
要设计线程安全的链表,必须采取同步措施,没得商量。
cppwin
2008-10-24
打赏
举报
回复
要点在于用 InterlockedCompareExchange(), 来保证 从比较到修改 是原子操作.
Enter时:
while( InterlockedCompareExchange( &m_nLock, 1, 0 ) ==0 ) {}
一般不用sleep, 因为sleep也一样导致线程切换.
如果你觉得你的具体情况需要使用sleep,考虑一下,使用信号量是不是更好.
使用Interlocked系列函数,要考虑具体环境,
它锁住系统数据总线,如果电脑cpu数较多,会引发频繁碰撞,效率反而低了.
在早期的单cpu电脑中,此系列函数的确是利器.
jianmuyan
2008-10-24
打赏
举报
回复
mark
cnzdgs
2008-10-24
打赏
举报
回复
[Quote=引用 7 楼 Idle_ 的回复:]
应用已经很具体了吧? 就是设计一种线程安全的单链表或双链表(这个更难),不使用信号量来同步各个线程的操作。
[/Quote]
我的意思是要根据具体的应用,主要是指如何使用链表,例如只有一个线程从表头取数据,其它线程向末尾添加数据,这是一种简单的应用。
如果要支持各种复杂应用,多个线程都做无规则的插入和删除,就只能用“锁”的方式,当然,这个锁不一定是同步对象,可以自己用变量和Interlocked指令来实现,但原理与用锁是相同的。
WinEggDrop
2008-10-24
打赏
举报
回复
[Quote=引用楼主 Idle_ 的帖子:]
1、多线程不加锁对单链表安全地插入/删除节点(包括修改头指针)。
2、多线程不加锁对双链表安全地插入/删除节点(包括修改头、尾指针)。
可能吗? 如何实现?
[/Quote]
LONG volatile IsLocked = 0; // 全局变量
VOID MyEnterLock()
{
LONG volatile CurrentValue = 0;
InterlockedExchange(¤tValue,IsLocked);
if (CurrentValue)
{
while(!CurrentValue)
{
Sleep(1);
InterlockedExchange(¤tValue,IsLocked);
}
InterlockedExchange(&IsLocked,1);
}
}
VOID MyReleaseLock()
{
InterlockedExchange(&IsLocked,0);
}
多线程中代码
MyEnterLock();
这里执行链表操作,删除,插入等
MyReleaseLock();
要求更为小的等待时间的话,将Sleep(1)改为用select(),select可以使用毫秒
除了这个,还有SetEvent()等一样可以做到.
sys0003
2008-10-24
打赏
举报
回复
线程同步当然得用互斥量、临界区、事件、自旋锁等,不然你咋保证同步
soliddream66
2008-10-24
打赏
举报
回复
这个类似多用户同时访问
参考com的话,可以用加数减数机制,每个多线程只改变自己备份
而本体可以根据多个备份的修改隔段时间更新一次
yjgx007
2008-10-24
打赏
举报
回复
用消息队列...
阿呆_
2008-10-24
打赏
举报
回复
[Quote=引用 5 楼 cnzdgs 的回复:]
在一些简单的情况,可以通过Interlocked指令来替代锁,如果要支持复杂的情况,当然不是一条Interlocked指令就能解决的,要看具体如何应用。
[/Quote]
应用已经很具体了吧? 就是设计一种线程安全的单链表或双链表(这个更难),不使用信号量来同步各个线程的操作。
同时回二楼:
这个问题应该很有现实意义的,如果用线程同步的方式,是只用一个锁来控制? 还是每个节点都用一个锁?前者造成同一时间只有一个线程允许访问链表,对效率有很大影响。后者一是浪费大量系统资源,二是插入/删除时至少需要锁两个锁, 稍不留神就会造成循环死锁。
阿呆_
2008-10-24
打赏
举报
回复
很显然,不能保证同一时间内只有一个线程访问链表。实际上问这个问题的目的就是要实现在多个线程同时访问情况下不用加锁就能做到安全插入/删除节点(允许脏读)
cnzdgs
2008-10-24
打赏
举报
回复
在一些简单的情况,可以通过Interlocked指令来替代锁,如果要支持复杂的情况,当然不是一条Interlocked指令就能解决的,要看具体如何应用。
chenyu2202863
2008-10-24
打赏
举报
回复
都可以实现,只要你保证不在同一时间有多个线程访问,就没问题
加载更多回复(3)
如何有效地对时间进行管理
有同学说现在对于时间管理和效率挺担心的,姐姐分享一个我觉得很好的文章,先来做测评吧。 下面是一个评测效率的小试题,大家都来做做看: 1,接到一个对自己来说很有
难度
的任务,你首先做的是: A.开始喊郁闷,心烦,安慰自己先休息一下,一会再来解决; B.寻找各种可能的解决办法,或者求助相关的人。 2,开始行动之前,你花了多少...
考研数学|张宇1000题 / 李永乐660题,怎么选?看这一篇!
我在基础强化阶段数学跟的老师是张宇老师。每当你学习完一个章节,我的建议是完成30讲上的例题和课后题后,就开始刷本章的知能行题目,每个章节按照你自己的掌握程度来看,1-2天时间可以刷完一个章节达到2级满。完成章节题目后,过段时间会出现综测,友情提示,一定要把章节刷到2级满后再开始另一个章节的题目,否则可能会出现综测爆炸的问题。当完成至少有一个章节后,每天会出现各个章节的综合测试,体现的是你的综合能力。每天起床第一事,先把综测搞定(hhhh),我在备考初期,由于当时英语单词需要一定时间。
程序员面试金典 - 面试题 01.01. 判定字符是否唯一
题目
难度
: 简单 原题链接 休息了一个月, 我又满血回来了 ???? 今天我们来开始一个新的系列 - leetcode 的程序员面试金典, 它相比剑指 Offer
难度
大了一些, 但大部分题目的出现频率仍然相当高, 推荐程度依旧 5 颗星 ✨✨✨✨✨ 最近一段时间我都挺忙的, 所以这个系列的更新频率可能不像之前那么高了, 估计几天一更吧. 不过更新时间还是老样子: 晚上的 6 点 45 分, 大家可以多多关注哦 另外大家在我的公众号"算法精选"中的聊天框中回复 面试金典 就能看到该系列当前已
NOI前的做题计划&&记录
每周要做的事: 三场比赛 5道黑题
难度
的题 10道紫题
难度
的题 争取每道做了的题都写题解 2021.4.22 最近就先卷卷whk,训练时间适当减少吧 上面的从五一后再开始执行吧
时间规划方法
文章目录1. 以“专注力”为中心,对时间分配进行思考2. 重启专注力,创造出时间3.要花时间进行自我投资4. 为了快乐而使用时间5. 15·45·90法则6. 杂念排除法 这本书是我在中大图书馆的推荐架上无意之间看到的,正好从那走过,随手拿起,觉得挺有趣的,就借阅下来了。这本书的作者是日本的一位神经科医生,讲的是如何规划时间,以及提高工作效率的一些理论和方法。 书名 *时间控 作者...
进程/线程/DLL
15,471
社区成员
49,181
社区内容
发帖
与我相关
我的任务
进程/线程/DLL
VC/MFC 进程/线程/DLL
复制链接
扫一扫
分享
社区描述
VC/MFC 进程/线程/DLL
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章