开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

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

[C#图文教程] 转载 多线程的那点儿事(之多线程数据结构)

[复制链接]

结帖率:100% (5/5)
发表于 2012-6-27 11:30:14 | 显示全部楼层 |阅读模式   山西省临汾市
   要想编写多线程,那就要使用锁。而在软件编写中,数据结构是少不了的。所以,我们在编写多线程的时候,就需要考虑一下如何在数据结构中插入锁。当然,有些数据结构是没有锁的,所以自然这个锁并不一定是必须的。
    比如说,我们编写一个多线程堆栈,应该怎么做呢,
  1. typedef struct _STACK   
  2. {   
  3.     void* pData;   
  4.     int maxLen;   
  5.     int top;   
  6.     void* hLock;   
  7.       
  8.     STATUS (*push)(struct _STACK* pStack, void* pData, int size);   
  9.     STATUS (*pop)(struct _STACK* pStack, void* pData, int size);
复制代码
(1) 初始化操作
  1. STACK* get_new_stack(void* pData, int len, void* pLock)   
  2. {   
  3.     STACK* pStack;   
  4.          
  5.     if(NULL == pData || 0 == len)   
  6.         return NULL;   
  7.    
  8.     pStack = (STACK*)malloc(sizeof(STACK));   
  9.     assert(NULL != pStack);   
  10.    
  11.     memset(pStack, 0, sizeof(STACK));   
  12.     pStack->pData  = pData;   
  13.     pStack->maxLen = len;   
  14.       
  15.     if(NULL != pLock)   
  16.         pStack->hLock = pLock;   
  17.    
  18.     return pStack;   
  19. }   
复制代码
(2) 添加数据
  1. STATUS push(struct _STACK* pStack, void* pData, int size)   
  2. {   
  3.     assert(NULL != pStack && NULL != pData);   
  4.    
  5.     if(NULL != pStack->hLock)   
  6.         WaitForSingleObject((HANDLE)pStack->hLock, INFINITE);   
  7.    
  8.     if(pStack->top == pStack->maxLen){   
  9.         if(NULL != pStack->hLock)   
  10.             ReleaseMutex((HANDLE)pStack->hLock);   
  11.            
  12.         return ERROR;   
  13.     }   
  14.    
  15.     memmove((char*)pStack->pData + size * pStack->top, (char*)pData, size);   
  16.     pStack->top ++;   
  17.       
  18.     if(NULL != pStack->hLock)   
  19.         ReleaseMutex((HANDLE)pStack->hLock);           
  20.    
  21.     return OK;   
  22. }  
复制代码
(3) 对2进行优化,因为判断的条件比较复杂
  1. #define STACK_CHECK_LOCK(hLock) \   
  2. do{\   
  3.     if(hLock)\   
  4.         WaitForSingleObject((HANDLE)hLock, INFINITE);\   
  5. }while(0)   
  6.    
  7. #define STACK_CHECK_UNLOCK(hLock) \   
  8. do{\   
  9.     if(hLock)\   
  10.         ReleaseMutex((HANDLE)hLock);\   
  11. }while(0)  
复制代码
所以,2的代码可以修改为,
  1. STATUS push(struct _STACK* pStack, void* pData, int size)   
  2. {   
  3.     assert(NULL != pStack && NULL != pData);   
  4.    
  5.     STACK_CHECK_LOCK(pStack->hLock);   
  6.    
  7.     if(pStack->top == pStack->maxLen){   
  8.         STACK_CHECK_UNLOCK(pStack->hLock);   
  9.         return ERROR;   
  10.     }   
  11.    
  12.     memmove((char*)pStack->pData + size * pStack->top, (char*)pData, size);   
  13.     pStack->top ++;   
  14.       
  15.     STACK_CHECK_UNLOCK(pStack->hLock);         
  16.     return OK;   
  17. }  
复制代码
总结:
    (1)  一般来说,比较好的数据结构要兼有多线程和没有多线程两种情况
    (2)  如果需要用其他的锁代替mutex,直接换掉就可以,十分方便

结帖率:61% (35/57)

签到天数: 1 天

发表于 2012-7-11 06:15:44 | 显示全部楼层   海南省乐东黎族自治县
我来坐沙发。。嘿嘿{:3_226:}
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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