POSIX信号量

概念

POSIX信号量与SYSTEM信号量的作用相同,都同步操作,达到无冲突地访问共享资源。
但是不同的是,POSIX信号量可以用于线程间同步。其实,POSIX信号量是具有等待队列的计数器,它的相关函数存放在“semaphore.h”文件中。

初始化信号量

int sem_init(sem_t *sem, int pshared, unsigned int value);

参数:
pshared:0表示线程间共享,非0表示进程间共享。

value:信号量初始值,表示可用资源的数量。

销毁信号量

int sem_destroy(sem_t *sem);
//在用完semaphore变量后要调用sem_destroy()释放semaphore的相关资源

等待信号量

功能:等待信号量,会将信号量的值减1。

int sem_wait(sem_t *sem);
//调用sem_wait()可以获得资源(P操作),使得semaphore的值减1,如果调用sem_wait()时semapthore的值已经是0,则挂起等待。
//如果不希望挂起等待,可以调用sem_trywait()

发布信号量

功能:发布信号量,将信号量值加1,表示资源使用完毕,可以归还资源了

int sem_post(sem_t *sem);

//调用sem_post()可以释放资源(V操作),使得semaphore的值加1,同时唤醒挂起等待的线程。

生产者和消费者实现同步代码:

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<semaphore.h>

sem_t product;
sem_t consume;

void *thr_product(void *arg)
{
    while(1){
        sem_wait(&product);//?
        printf("product!\n");
        sleep(1);
        sem_post(&consume);//?
    }
}

void *thr_consume(void *arg)
{
     while(1){
        sem_wait(&consume);
        printf("consume!\n");
        sleep(1);
        sem_post(&product);
     }
}

int main()
{
    pthread_t tid1, tid2;
    int err;

    sem_init(&product, 0, 1);
    sem_init(&consume, 0, 0);
    
    err = pthread_create(&tid1, NULL, thr_product, NULL);
    if(err != 0){
        perror("create thread 1 error!\n");
        return -1;
    }
    err = pthread_create(&tid2, NULL, thr_consume, NULL);
    if(err != 0){
        perror("create thread 2 error!\n");
        return -1;
    }

    pthread_join(tid1, NULL);//?
    pthread_join(tid2, NULL);

    sem_destroy(&product);
    sem_destroy(&consume);

    return 0;
    
}

初始化信号量时把“product”的可用资源数量置1,这样,sem_wait(&product)将能执行。生产后把信号发布给“thr_consume”线程消费

展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客
应支付0元
点击重新获取
扫码支付

支付成功即可阅读