线程间的同步----利用互斥量来实现

#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 1024char 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);// 结束线程}

,人之所以有一张嘴,而有两只耳朵,原因是听的要比说的多一倍。

线程间的同步----利用互斥量来实现

相关文章:

你感兴趣的文章:

标签云: