线程间的同步----利用互斥量来实现
2015-04-27 21:03
274 查看
#include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <string.h> #include <pthread.h> // 包含线程库 #include <semaphore.h> // 包含信号量库 void *thread_function(void *arg); // 定义线程函数原型 pthread_mutex_t work_mutex; // 定义互斥量 #define WORK_SIZE 1024 char work_area[WORK_SIZE]; // 定义公用的内存空间 int time_to_exit = 1; // 用于控制循环 int main() { int res; pthread_t a_thread; // 用于保存创建线程的返回值 void *thread_result; // 用于接收线程结束是的返回值 res = pthread_mutex_init(&work_mutex, NULL); // 创建并初始化互斥量 if (res != 0) { // 判断互斥量创建是否成功 perror("初始化互斥量失败"); exit(EXIT_FAILURE); } res = pthread_create(&a_thread, NULL, thread_function, NULL); // 创建线程 if (res != 0) { // 判断创建线程是否有错误 perror("线程创建失败"); exit(EXIT_FAILURE); } pthread_mutex_lock(&work_mutex); // 锁定互斥量 printf("请输入要传送的信息,输入'end'退出\n"); while (time_to_exit) { // 判断循环标志状态 fgets(work_area, WORK_SIZE, stdin); // 接收输入信息 pthread_mutex_unlock(&work_mutex); // 解锁互斥量 while (1) { pthread_mutex_lock(&work_mutex); // 锁定互斥量 if (work_area[0] != '\0') { // 判断公共内存空间是否为空 pthread_mutex_unlock(&work_mutex); // 解锁互斥量 sleep(1); // 原有线程睡眠1秒 } else { break; // 结束循环 } } } pthread_mutex_unlock(&work_mutex); // 解锁互斥量 printf("\n等待线程结束...\n"); res = pthread_join(a_thread, &thread_result); // 等待线程结束 if (res != 0) { // 判断结束线程是否有错误 perror("线程结束失败"); exit(EXIT_FAILURE); } printf("线程结束\n"); pthread_mutex_destroy(&work_mutex); // 清除互斥量 exit(EXIT_SUCCESS); } void *thread_function(void *arg) // 定义线程函数细节 { sleep(1); // 子线程睡眠1秒 pthread_mutex_lock(&work_mutex); // 锁定信号量 while (strncmp("end", work_area, 3) != 0) { // 判断收到的信息是否是“end” printf("收到%d个字符\n", strlen(work_area) - 1); work_area[0] = '\0'; // 将公共空间清除 pthread_mutex_unlock(&work_mutex); // 解锁互斥量 sleep(1); // 子线程睡眠1秒 pthread_mutex_lock(&work_mutex); // 判断公共空间是否为空 while (work_area[0] == '\0') { pthread_mutex_unlock(&work_mutex); // 解锁互斥量 sleep(1); // 子线程睡眠1秒 pthread_mutex_lock(&work_mutex); // 锁定互斥量 } } time_to_exit = 0; // 将循环结束标志置为0 work_area[0] = '\0'; // 清楚公共空间 pthread_mutex_unlock(&work_mutex); // 解锁互斥量 pthread_exit(0); // 结束线程 }
相关文章推荐
- Visual C++利用互斥量同步线程实现文件读取进度条
- Visual C++利用互斥量同步线程实现文件读取进度条
- 利用条件变量实现线程间同步
- VC中利用多线程技术实现线程之间的通信(三)---线程之间的同步
- 孙鑫VC学习笔记:第十六讲 (二) 利用关键代码段实现线程间的同步
- android 利用countDownLatch实现主线程与子线程之间的同步
- 孙鑫VC学习笔记:第十六讲 (一) 利用事件对象实现线程间的同步
- 孙鑫VC学习笔记:第十六讲 利用事件对象实现线程间的同步
- 孙鑫VC学习笔记:第十六讲 利用关键代码段实现线程间的同步
- Linux利用信号量实现线程的同步与互斥
- 利用面向对象的思想实现主从线程下多次循环的切换(因为他们要同步,所以他们是有关联的,所以把它们放在一个类里)
- 使用互斥量实现线程间同步
- 详解Java利用ExecutorService实现同步执行大量线程
- 如何利用c++11的新特性编写类成员线程函数并实现同步
- 线程间的同步----利用信号量来实现
- 多线程编程Demo[利用互斥对象实现线程间同步]
- 利用条件变量实现线程间同步
- 线程间同步之信号量实现环形buf
- 如何利用触发器实现两个数据库间的同步
- rsync参数详解、利用ssh、rsync 实现数据的定时同步