原创 ubuntu 用互斥量进行同步

2024-6-14 12:10 264 5 5 分类: 软件与OS 文集: Linux
代码:

#include 
#include 
#include 
#include 
#include 											// 包含线程库
#include 											// 包含信号量库
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);												// 结束线程
}
运行

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
5
关闭 站长推荐上一条 /3 下一条