Linux线程同步

1. 线程间同步

同步 (synchronization)指的是多个任务(线程)按照约定的顺序相互配合完成一件事。

2.线程间同步-P/V操作

1) 信号量代表某一类资源,其值表示系统中该资源的数量

2) 信号量是一个受保护的变量,只能通过三种操作来访问

       a)初始化

       b)P操作(申请资源)

       c)V操作(释放资源)

3)信号量的值为非负整数

4) P(S) 操作和 V(S)操作代表含义如下:

P(S) 代表的含义:

if(信号量减一,若信号量大于等于0)

{程序继续执行}

else

{程序阻塞}

V(S) 代表的含义:

if(信号量加1,若结果小于等于0)

{唤醒队列中第一个阻塞的进程}

else

{不必唤醒}

3. pthread库常用的信号量操作函数

函数sem_init()

头文件:#include<semaphore.h>

函数原型:int sem_init(sem_t *sem, int pshared, unisgned int value)

函数参数:sem        信号量对象

                  pshared  信号量共享的范围(0:线程间使用,非0:进程间使用)

                  value      信号量初始化的值

函数返回值:成功:0

                    失败:-1

其余5个函数

int sem_wait(sem_t *sem) //信号量减1(P操作),若不成功则等待

int sem_trywait(sem_t *sem)   //信号量减1(P操作),若不成功则返回错误,并不会阻塞线程

int sem_post(sem_t *sem) //信号量加1(V操作)并释放一个阻塞的线程

int sem_getvalue(sem_t *sem)//获取信号量的值

int sem_destroy(sem_t *sem)  //删除信号量

示例代码:

/*************************************************************************

 @Author: wanghao

 @Created Time : Tue 22 May2018 05:11:02 AM PDT

 @File Name: semaphore.c

 @Description:

 ************************************************************************/

#include <stdio.h>  

#include <string.h>

#include <pthread.h>

#include <semaphore.h>

#include <stdlib.h>

char buf[32];

sem_t sem;

void *function(void *arg);

int main(int argc, const char *argv[])

{

    pthread_t a_thread;

    void *pthread_result;

    if(sem_init(&sem, 0, 0)< 0)

    {

           perror("fail tosem_init");

           exit(-1);

    }

    if(pthread_create(&a_thread,NULL, function, NULL) < 0)

    {

           perror("fail topthread_create");

           exit(-1);

    }

    printf("input 'quit'to exit\n");

    do{

           fgets(buf, 60,stdin);

           sem_post(&sem);

    }while(strncmp(buf,"quit", 4) != 0);

    return 0;

}

void *function(void *arg)

{

    while(1)

    {

           sem_wait(&sem);

           printf("Youenter %s",buf);

    }

}


猜你喜欢

转载自blog.csdn.net/weixin_42048417/article/details/80411515
今日推荐