免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 23346 | 回复: 19
打印 上一主题 下一主题

不用锁实现队列读写? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-05 23:32 |只看该作者 |倒序浏览
今日去面试,面试官说不用锁实现一个队列,这个队列只有一个进程读和一个进程写,应该怎样实现呢?

论坛徽章:
0
2 [报告]
发表于 2009-05-06 09:17 |只看该作者
CPU在操作同一个内存地址时会锁住总线,这时不会中断,也就不会线程切换。

这样实现的

论坛徽章:
0
3 [报告]
发表于 2009-05-06 09:18 |只看该作者
用signal符合要求不:
1、进程1写队列,直到队列满开始发送一个信号给进程2,此时进程1开始等待队列不为满的信号;
2、进程2开始时等待一个读的信号,当进程1发给它一个信号时它将读取队列并删除已读的节点,同时发送信号给进程1;
3、返回第一步

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
4 [报告]
发表于 2009-05-06 09:19 |只看该作者
原帖由 yuhang001 于 2009-5-5 23:32 发表
今日去面试,面试官说不用锁实现一个队列,这个队列只有一个进程读和一个进程写,应该怎样实现呢?


只有一个进程读,一个进程写,那就意味着不会出现并发的读,和并发的写。于是,写的往队列尾部写,读的从队列头部度;写的时候,先判断队列是否满了,如果没满,则写,写完了增加队列计数;读的时候,判断队列是否非空,非空的话,则读出来后,再减少队列元素计数。

论坛徽章:
0
5 [报告]
发表于 2009-05-06 10:06 |只看该作者
如果兼顾并行和防止队空的操作的话设置一个对首指针和一个队尾指针,为了防止并行使得数据错乱,我想使用链表结构
入队的时候申请空间,然后写入数据,再把对尾指针延后
出队的时候如果非空,先把队尾指针后移,这样操作类似于出队应该不会出现并行问题
同时对于同一个队列空间是互斥操作,因为空间都是链表独立的,一旦出队就访问不到了,而且入队的时候先申请空间填好然后才入队,也避免了两个写进程往队列同一块空间写,个人认为应该可以的
不对的请指正

[ 本帖最后由 daybreakcx 于 2009-5-6 10:15 编辑 ]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
6 [报告]
发表于 2009-05-06 10:35 |只看该作者
IPC 呀,用消息队列不行吗?

论坛徽章:
0
7 [报告]
发表于 2009-05-06 11:07 |只看该作者
http://b.cnc.qzone.qq.com/cgi-bi ... imestamp=1241579164

我试写了一个,不知道会不会出错,10000的数字排的正确

论坛徽章:
0
8 [报告]
发表于 2009-05-06 11:10 |只看该作者
楼上效率不低啊,这么快就发日志了

论坛徽章:
0
9 [报告]
发表于 2009-05-06 11:15 |只看该作者
除非说的是可以使用隐含的锁或者自己实现锁,不然楼上几位的做法都不能解决并发冲突。

论坛徽章:
0
10 [报告]
发表于 2009-05-06 11:36 |只看该作者
了解的比较模糊:
多CPU多核操作总线,在北桥芯片里面就已经固化了一个锁了。
对同一内存地址操作(读后写)已经是有lock free
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP