
目录

1. 同步
1.1 概念
同步(synchronization)指的是多个任务(线程)按照约定的顺序相互配合完成一件事情
1.2 同步机制
通过信号量实现线程间的同步
信号量:通过信号量实现同步操作;由信号量来决定线程是继续运行还是阻塞等待.
信号量代表某一类资源,其值表示系统中该资源的数量:
信号量的值>0,表示有资源可以用, 可以申请到资源,
信号量的值<=0, 表示没有资源可以用, 无法申请到资源, 阻塞.
信号量还是一个受保护的变量,只能通过三种操作来访问:初始化、P操作(申请资源)、V操作(释放资源)
sem_init: 信号量初始化
sem_wait: 申请资源,P操作, 如果没有资源可以用, 阻塞,-1
sem_post: 释放资源,V操作, 非阻塞 +1
1.3 函数接口
int sem_init(sem_t *sem, int pshared, unsigned int value)
功能:初始化信号量
参数:sem:初始化的信号量对象
pshared:信号量共享的范围(0: 线程间使用 非0:1进程间使用)
value:信号量初值
返回值:成功 0
失败 -1
int sem_wait(sem_t *sem)
功能:申请资源 P操作
参数:sem:信号量对象
返回值:成功 0
失败 -1
注:此函数执行过程,当信号量的值大于0时,表示有资源可以用,则继续执行,同时对信号量减1;当信号量的值等于0时,表示没有资源可以使用,函数阻塞
int sem_post(sem_t *sem)
功能:释放资源 V操作
参数:sem:信号量对象
返回值:成功 0
失败 -1
注:释放一次信号量的值加1,函数不阻塞
#include <stdio.h>
#include <string.h>
#include <pthread.h>
#include <semaphore.h>
sem_t sem;
char str[32];
void *handler_thread(void *arg)
{
while (1) //输出
{
//申请资源
sem_wait(&sem); //P操作,申请到资源-1,申请不到会阻塞等待着申请资源
if (strcmp(str, "quit") == 0)
break;
printf("%s\n", str);
}
}
int main(int argc, char const *argv[])
{
pthread_t tid;
if (pthread_create(&tid, NULL, handler_thread, NULL) != 0)
{
perror("thread create err");
return -1;
}
//信号量初始化
if (sem_init(&sem, 0, 0) != 0)
{
perror("sem_init err");
return -1;
}
while (1) //输入
{

最低0.47元/天 解锁文章
289

被折叠的 条评论
为什么被折叠?



