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

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

时间: 2024-10-20 16:10:56

线程间的同步----利用互斥量来实现的相关文章

浅析线程间通信一:互斥量和条件变量

线程同步的目的简单来讲就是保证数据的一致性.在Linux中,常用的线程同步方法有互斥量( mutex ).读写锁和条件变量,合理使用这三种方法可以保证数据的一致性,但值得的注意的是,在设计应用程序时,所有的线程都必须遵守相同的数据访问规则为前提,才能保证这些同步方法有效,如果允许某个线程在没有得到访问权限(比如锁)的情况下访问共享资源,那么其他线程在使用共享资源前都获得了锁,也会出现数据不一致的问题.另外还有自旋锁.barrier和信号量线程同步方法.本文将讨论互斥量和条件变量的使用,并给出了相

Linux 线程间的同步与互斥

在线程并发执行的时候,我们需要保证临界资源的安全访问,防止线程争抢资源,造成数据二义性. 线程同步: 条件变量 为什么使用条件变量? 对临界资源的时序可控性,条件满足会通知其他等待操作临界资源的线程,类似信号. 场景:T-DAY展会排队参观/生产者消费者模型 条件变量是什么? 是一种同步机制,一个线程用于修改这个变量使其满足其它线程继续往下执行的条件,其它线程则接收条件已经发生改变的信号. 条件变量操作? 初始化和销毁    pthread_cond_wait 条件不满足 会释放锁并阻塞等待 ,

嵌入式开发之hi3519---进程线程间的同步和互斥,条件变量、信号了、互斥锁等

sem_post 最安全 sem  有序,会卡顿 阻塞 mutex  无序,不能同步 http://blog.chinaunix.net/uid-20671208-id-4935154.html https://www.cnblogs.com/ngnetboy/p/3521547.html http://www.jianshu.com/p/1e59f0970bf5 http://blog.csdn.net/jenny8080/article/details/52094140

一起talk C栗子吧(第一百一十六回:C语言实例--线程同步之互斥量二)

各位看官们,大家好,上一回中咱们说的是线程同步之信号量的例子,这一回咱们继续说该例子.闲话休提,言归正转.让我们一起talk C栗子吧! 我们在上一回中详细介绍了互斥量相关函数的用法,这一回中,我们介绍如何使用这些函数来操作互斥量. 下面是详细的操作步骤: 1.定义一个互斥量A,用来同步线程: 2.在创建线程的进程中使用pthread_mutex_init函数初始化互斥量,互斥量的属性使用默认值: 3.在读取数据的线程中读取数据,首先使用pthread_mutex_lock函数对互斥量A进行加锁

线程的同步之互斥量

互斥量: 当多个线程共享相同的内存时,需要每一个线程看到相同的视图.当一个线程修改变量时,而其他线程也可以读取或者修改这个变量,就需要对这些线程同步,确保他们不会访问到无效的变量 在变量修改时间多于一个存储器访问周期的处理器结构中,当存储器的读和写这两个周期交叉时,这种潜在的不一致性就会出现.当然这与处理器相关,但是在可移植的程序中并不能对处理器做出任何假设 为了让线程访问数据不产生冲突,这要就需要对变量加锁,使得同一时刻只有一个线程可以访问变量.互斥量本质就是锁,访问共享资源前对互斥量加锁,访

vc++高级班之多线程篇[7]---线程间的同步机制②

//示例代码: CStringArray g_ArrString; UINT __cdecl ThreadProc(LPVOID lpParameter) { int startIdx = (int)lpParameter; for (int idx = startIdx; idx < startIdx+100; ++idx) { CString str; str.Format(_T("%d"), idx); g_ArrString.Add(str); } return 0; }

Linux 多线程同步机制:互斥量、信号量、条件变量

互斥量:互斥量提供对共享资源的保护访问,它的两种状态:lock和unlock,用来保证某段时间内只有一个线程使用共享资源,互斥量的数据类型是pthread_mutex_t主要涉及函数:pthread_mutex_lock() pthread_mutex_trylock() pthread_mutex_unlock()Pthreaf_mutex_init() pthread_mutex_destroy()lock与unlock之间所锁定的区域为临界区域(如果只加锁不解锁程序会阻塞等待)信号量:信号

vc++高级班之多线程篇[6]---线程间的同步机制①

①.线程同步的必要性: int g_Num = 0; UINT __cdecl ThreadProc(LPVOID lpParameter) { for (int idx = 0; idx < 100; ++idx) { g_Num = g_Num+1; CString strNum; strNum.Format(_T("%d"), g_Num); g_Num = g_Num-1; } return 0; } void CThreadTestDlg::OnBnClickedBtn

C#学习笔记---线程同步:互斥量、信号量、读写锁、条件变量

http://www.cnblogs.com/maxupeng/archive/2011/07/21/2112282.html 一.互斥量(mutex) 互斥量本质上是一把锁,在访问共享资源前对互斥量进行加锁,在访问完成后释放互斥量上的锁. 对互斥量进行加锁以后,任何其它试图再次对互斥量加锁的线程将会被阻塞直到当前线程释放该互斥锁.如果释放互斥锁时有多个线程阻塞,所有在该互斥锁上的阻塞线程都会变成可运行状态,第一个变为运行状态的线程可以对互斥量加锁,其它线程将会看到互斥锁依然被锁住,只能回去再次