线程同步的方法

本文详细介绍了线程同步的概念及其重要性,探讨了数据共享、线程竞争及合理同步机制的缺失如何影响线程的正确运行。文章深入解析了互斥锁的工作原理,并通过代码示例展示了如何在多线程环境中使用互斥锁来保护共享资源,确保数据的一致性和程序的稳定性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程同步概念:线程按照先后次序运行;
线程同步指一个线程发出某一功能调用时,在没有得到结果之前,该调用不返回。同时其他线程为保证数据的一致性,不能调用该功能;
需要线程同步的原因:1.数据共享;2.线程之间竞争;3.多个对象没有合理的同步机制;(前2点不能改变,因此只能修改第三点)

互斥量(互斥锁):锁不具有强制性(建议锁)
读写锁:
条件变量:
信号量:
进程间同步:1.信号量;2.文件锁,
restrict关键字:只用于限制指针,告诉编译器,所有修改该指针指向内存中内容的操作,只能通过本指针完成,不能通过本指针以外的其他变量或者指针修改,意思就是不能定义一个相同类型的指针接收这个指针的值,然后修改内存中的内容;

  1 #include <stdio.h>
  2 #include <string.h>
  3 #include <stdlib.h>
  4 #include <pthread.h>
  5 #include <unistd.h>
  6 pthread_mutex_t mutex;//定义锁
  7 void* tfn(void* arg)
  8 {
  9         srand(time(NULL));
 10         while(1)
 11         {
 12                 pthread_mutex_lock(&mutex);
 13                 printf("hello ");
 14                 sleep(rand()%3);
 15                 printf("world\n");
 16                 pthread_mutex_unlock(&mutex);
 17                 sleep(rand()%3);
 18         }
 19         return NULL;
 20 }
 21 
 22 int main()
 23 {
 24         int flag = 5;
 25 
 26         pthread_t tid;
 27         srand(time(NULL));
 28         pthread_mutex_init(&mutex,NULL);//mutex == 1
 29         pthread_create(&tid,NULL,tfn,NULL);
 30         while(flag--)
 31         {
 32                 pthread_mutex_lock(&mutex);
 33                 printf("HELLO ");
 34                 sleep(rand()%3);
 35                 printf("WORLD\n");
 36                 pthread_mutex_unlock(&mutex);
 37                 sleep(rand()%3);
 38 
 39         }
 40         pthread_cancel(tid);
 41         pthread_join(tid,NULL);
 42         pthread_mutex_destroy(&mutex);//mutex == 0
 43 
 44         return 0;
 45 }`
 结论:在访问共享资源前枷锁,访问结束后**立即解锁**;锁的粒度越小越好;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值