开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 3791|回复: 1
收起左侧

[C#图文教程] 转载 多线程的那点儿事(之无锁链表)

[复制链接]

结帖率:100% (5/5)
发表于 2012-6-27 11:26:31 | 显示全部楼层 |阅读模式   山西省临汾市
前面,为了使得写操作快速进行,我们定义了顺序锁。但是顺序锁有个缺点,那就是处理的数据不能是指针,否则可能会导致exception。那么有没有办法使得处理的数据包括指针呢?当然要是这个链表没有锁,那就更好了。
    针对这种无锁链表,我们可以初步分析一下,应该怎么设计呢?   
    (1)读操作没有锁,那么怎么判断读操作正在进行呢,只能靠标志位了;
    (2)写操作没有锁,那么读操作只能一个线程完成;
    (3)写操作中如果是添加,那么直接加在末尾即可;
    (4)写操作中如果是删除,那么应该先删除数据,然后等到当前没有操作访问删除数据时,释放内存,但是首节点不能删除。

    普通链表的结构为,
  1. typedef struct _LINK   
  2. {   
  3.     int data;   
  4.     struct _LINK* next;   
  5. }LINK;  
复制代码
假设此时有32个线程在访问链表,那么可以定义一个全局变量value,每一个bit表示一个thread,读操作怎么进行呢
  1. void read_process()   
  2. {   
  3.     int index = get_index_from_threadid(GetThreadId());   
  4.     InterLockedOr(&value, 1 << index);   
  5.     /* read operation */   
  6.     InterLockedAnd(&value, ~(1<< index));      
  7. }  
复制代码
那么,写操作怎么进行呢,
  1. void write_process_add(LINK* pHead, LINK* pLink)   
  2. {   
  3.     /* add link to the tail of list */   
  4. }   
  5.    
  6. void write_process_del(LINK* pHead, LINK* pLink)   
  7. {   
  8.     delete_link_from_list(pHead, pLink);   
  9.     while(1){   
  10.         if(0 == value)   
  11.             break;   
  12.          Sleep(100);   
  13.     }   
  14.    
  15.     free(pLink);   
  16. }  
复制代码
其中链表的删除操作为,
  1. [cpp] view plaincopyprint?/*  
  2. *  From:   
  3. *    ->   a  ->  b -> c -> d  
  4. *  
  5. *  To:  
  6. *        -----------------  
  7. *        |               V  
  8. *    ->  a        b  ->  c ->d   
  9. *                                 
  10. */  
复制代码
总结:     (1)这种无锁链表有很多局限:多读少写、注意使用原子操作、不能删除头结点、数据只能添加到尾部、注意删除顺序和方法、读线程个数有限制等等;
    (2)写操作在操作前需要等待所有的读操作,否则有可能发生异常;
    (3)写操作不能被多个线程使用;
(4)无锁链表应用范围有限,只是特殊情况下的一种方案而已。

结帖率:61% (35/57)
发表于 2012-7-11 06:15:20 | 显示全部楼层   海南省乐东黎族自治县
必须支持C#此板块!{:3_232:}
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表