线程(create、mutex、cond)

线程与进程区别

1、进程独占内存空间,线程共享内存空间
2、通信,进程间的数据相互独立,线程间数据共享,通信时,不需要通过操作系统
3、进程的调度切换速度慢,线程的速度快<共享地址空间>

二者之间的关系

管家和马仔的关系,马仔主要干活;管家分配金钱。
同理,进程拥有资源,线程是执行的最小单位。
雇佣多个管家干活,效率低、还浪费资源;因此提倡使用多线程。

目的

1、节约资源
2、提高效率

线程

1、创建

pthread_create()//创建线程  man pthread_create
pthread_join();//主线程等待子线程结束
pthread_exit();//线程退出
pthread_self();//获取线程id
//函数也好理解,跟进程的创建、父子进程等待都差不多

2、创建大量线程时,需要使用循环的方式来创建线程,线程主要根据线程id来区分

由于线程之间共享资源,线程并发执行且之间抢占资源导致出现的结果杂乱无章,引进同步机制,如互斥锁、条件变量、读写锁

互斥锁

加锁和解锁会成对出现

pthread_mutex_t mutex; //互斥量
pthread_mutex_init();//初始化
//动态初始化时,需要destroy(),如new delete一样
pthread_mutex_destory();//摧毁
pthread_mutex_lock();//加锁
pthead_mutex_unlock()//解锁
pthread_mutex_trylock()//加锁是否成功,利用返回值判断

互斥量与信号量
互斥量是通过锁机制来实现线程的同步;信号量是通过数值来实现进程同步。

产生死锁的原因:

1、线程持有锁资源死亡
2、一个互斥量尝试两次加锁

解决方法:

条件变量
理解:
当某个条件成立时,则从阻塞的位置开始执行

pthread_cond_wait();//阻塞等待,并且释放互斥量资源
pthread_cond_signal();//加锁,唤醒阻塞
pthread_cond_timedwait();//定时等待
pthread_cond_broadcast();//广播唤醒

代码

代码在这!!

总结

1、加锁和解锁用于共享内存,且成对出现
2、锁机制会出现,死锁情况解决方法
2.1、利用条件变量 pthread_cond_wait()
作用:1、等待阻塞 2、释放互斥量<等待阻塞队列,根据条件变量来唤醒>
2.2、利用pthread_cond_signal()
作用:1、加锁机制 2、唤醒等待阻塞的位置,执行

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pthread_mutex_init: 用于初始化互斥锁(mutex),将互斥锁设置为默认属性。 ```c #include <pthread.h> int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *attr); ``` pthread_cond_init: 用于初始化条件变量(condition variable),将条件变量设置为默认属性。 ```c #include <pthread.h> int pthread_cond_init(pthread_cond_t *cond, const pthread_condattr_t *attr); ``` pthread_create: 用于创建一个新的线程,并执行指定的函数。 ```c #include <pthread.h> int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void*), void *arg); ``` pthread_cond_signal: 用于唤醒一个等待在条件变量上的线程。 ```c #include <pthread.h> int pthread_cond_signal(pthread_cond_t *cond); ``` pthread_mutex_unlock: 用于解锁互斥锁,允许其他线程获取该互斥锁。 ```c #include <pthread.h> int pthread_mutex_unlock(pthread_mutex_t *mutex); ``` pthread_mutex_lock: 用于加锁互斥锁,如果互斥锁已经被锁定,则调用线程会阻塞直到互斥锁被解锁。 ```c #include <pthread.h> int pthread_mutex_lock(pthread_mutex_t *mutex); ``` 下面是一个使用这些函数的简单示例: ```c #include <stdio.h> #include <pthread.h> pthread_mutex_t mutex; pthread_cond_t cond; int count = 0; void* thread_func(void* arg) { pthread_mutex_lock(&mutex); // 检查条件是否满足 while (count < 10) { // 等待条件变量被唤醒 pthread_cond_wait(&cond, &mutex); } // 条件满足,执行任务 printf("Thread: Count is now %d\n", count); pthread_mutex_unlock(&mutex); return NULL; } int main() { pthread_t thread; pthread_mutex_init(&mutex, NULL); pthread_cond_init(&cond, NULL); // 创建线程 pthread_create(&thread, NULL, thread_func, NULL); // 模拟更新计数 for (int i = 0; i < 15; ++i) { pthread_mutex_lock(&mutex); count++; // 每次更新计数后,唤醒等待的线程 if (count >= 10) { pthread_cond_signal(&cond); } pthread_mutex_unlock(&mutex); } // 等待线程结束 pthread_join(thread, NULL); pthread_mutex_destroy(&mutex); pthread_cond_destroy(&cond); return 0; } ``` 在上面的示例中,主线程更新一个计数器,当计数器达到10时,会通过条件变量唤醒等待的线程。等待的线程在条件满足时执行任务,并输出计数器的值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值