小白学c++之多线程互斥锁
来源:互联网 发布:淘宝土家酱香饼纸袋 编辑:程序博客网 时间:2024/06/05 11:40
#include <stdio.h>#include <stdlib.h>#include <pthread.h>#include <unistd.h>pthread_mutex_t lock;int ticketcount=5;void* salewinds1(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window1 start %d\n",ticketcount);sleep(1);ticketcount--;printf("sale ticket finish:%d\n",ticketcount);}else{pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁pthread_exit(NULL);}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}void* salewinds2(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window2 start:%d\n",ticketcount);sleep(1);ticketcount--;printf("sale finish:%d\n",ticketcount);}else{pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁pthread_exit(NULL);}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}int main(int argc,const char* argv[]){pthread_t thd1;pthread_t thd2;int val1=1;int val2=2;pthread_mutex_init(&lock,NULL);pthread_create(&thd1,NULL,salewinds1,NULL);pthread_create(&thd2,NULL,salewinds2,NULL);pthread_join(thd1,(void**)&val1);pthread_join(thd2,(void**)&val2);printf("val1:%d....val2:%d\n",val1,val2);pthread_mutex_destroy(&lock);return 0;}
如果一个线程被加锁,一定要在线程退出前解锁,否则不解锁的线程不会执行pthread_exit,除非使用exit直接终止进程。
#include <stdio.h>#include <stdlib.h>#include <pthread.h>#include <unistd.h>pthread_mutex_t lock;int ticketcount=5;void* salewinds1(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window1 start %d\n",ticketcount);sleep(1);ticketcount--;printf("sale ticket finish:%d\n",ticketcount);}else{pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁pthread_exit(NULL);}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}void* salewinds2(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window2 start:%d\n",ticketcount);sleep(1);ticketcount--;printf("sale finish:%d\n",ticketcount);}else{//pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁//pthread_exit(NULL);exit(1);}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}int main(int argc,const char* argv[]){pthread_t thd1;pthread_t thd2;int val1=1;int val2=2;pthread_mutex_init(&lock,NULL);pthread_create(&thd1,NULL,salewinds1,NULL);pthread_create(&thd2,NULL,salewinds2,NULL);pthread_join(thd1,(void**)&val1);pthread_join(thd2,(void**)&val2);printf("val1:%d....val2:%d\n",val1,val2);pthread_mutex_destroy(&lock);return 0;}
可以正常退出。
</pre><pre name="code" class="cpp">
#include <stdio.h>#include <stdlib.h>#include <pthread.h>#include <unistd.h>pthread_mutex_t lock;int ticketcount=5;void* salewinds1(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window1 start %d\n",ticketcount);sleep(1);ticketcount--;printf("sale ticket finish:%d\n",ticketcount);}else{//pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁//pthread_exit(NULL);//exit(1);return NULL;}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}void* salewinds2(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window2 start:%d\n",ticketcount);sleep(1);ticketcount--;printf("sale finish:%d\n",ticketcount);}else{//pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁//pthread_exit(NULL);//exit(1);return NULL;}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}int main(int argc,const char* argv[]){pthread_t thd1;pthread_t thd2;int val1=1;int val2=2;pthread_mutex_init(&lock,NULL);pthread_create(&thd1,NULL,salewinds1,NULL);pthread_create(&thd2,NULL,salewinds2,NULL);pthread_join(thd1,(void**)&val1);pthread_join(thd2,(void**)&val2);printf("val1:%d....val2:%d\n",val1,val2);pthread_mutex_destroy(&lock);return 0;}不可以正常退出
#include <stdio.h>#include <stdlib.h>#include <pthread.h>#include <unistd.h>pthread_mutex_t lock;int ticketcount=5;void* salewinds1(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window1 start %d\n",ticketcount);sleep(1);ticketcount--;printf("sale ticket finish:%d\n",ticketcount);}else{pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁//pthread_exit(NULL);//exit(1);return NULL;}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}void* salewinds2(void* args){while(1){pthread_mutex_lock(&lock);if(ticketcount>0){printf("window2 start:%d\n",ticketcount);sleep(1);ticketcount--;printf("sale finish:%d\n",ticketcount);}else{//pthread_mutex_unlock(&lock);//这句如果不加会造成程序死锁//pthread_exit(NULL);//exit(1);return NULL;}pthread_mutex_unlock(&lock);sleep(1);}return NULL;}int main(int argc,const char* argv[]){pthread_t thd1;pthread_t thd2;int val1=1;int val2=2;pthread_mutex_init(&lock,NULL);pthread_create(&thd1,NULL,salewinds1,NULL);pthread_create(&thd2,NULL,salewinds2,NULL);pthread_join(thd1,(void**)&val1);pthread_join(thd2,(void**)&val2);printf("val1:%d....val2:%d\n",val1,val2);pthread_mutex_destroy(&lock);return 0;}可以退出,有时也可能不会退出,跟加锁的位置有关
0 0
- 小白学c++之多线程互斥锁
- Linux C之多线程
- 实例解析C++/CLI线程之多任务
- 实例解析C++/CLI线程之多任务
- Linux+C学习笔记之多线程
- linux c socket之多线程任务
- c语言小技巧-之多线程创建
- 学习Linux C编程之多线程编程
- 小白学c++之多线程共享资源
- 小白学c++之多线程函数返回值
- C++之多线程编程互斥锁-四
- android线程之多线程
- GroboUtils之多线程测试
- Java学习之多线程
- java基础教程之多线程
- ecl之多线程
- Qt之多线程(一)
- Qt之多线程(二)
- 大话设计模式C++实现-第25章-中介者模式
- WordPress程序打开速度慢的三种解决方法
- Spring MVC 学习笔记8 —— 实现简单的用户管理(4)
- Android 基于google Zxing实现二维码、条形码扫描,仿微信二维码扫描效果
- ExpandableListActivity 的使用
- 小白学c++之多线程互斥锁
- maven assembly打出的独立可执行jar包找不到xml schema解决,使用shade插件
- adobe flash player升级coredump分析
- 判斷選擇的日期區間必須在某個範圍內,比如選擇的日期區間在必須三個月內
- Android 开源框架ActionBarSherlock 和 ViewPager 仿网易新闻客户端
- 正则表达式初步
- js 动态合并表格单元格
- 产品经理们都是怎样养成的?
- back for creepcrack.inp