zoukankan      html  css  js  c++  java
  • 信号量

    信号量(信号灯)

    mutex初始化为1
    lock之后为0
    unlock之后为1
    mutex实现的同步都是串行的

    sem相当于有多个mutex, 并行

    (1) 头文件: semaphore.h

    (2) 信号量类型: sem_t; 加强版互斥锁

    (3) 主要函数

    初始化信号量:int sem_init(sem_t *sem, int pshared, unsigned int value);
      0 线程同步
      1 进程同步
      value: 最多有几个线程操作共享数据

    销毁信号int sem_destroy(sem_t *sem);

    加锁
    int sem_wait(sem_t *sem);
    调用一次相当于对sem做了-1操作
    如果sem值为0, 线程会阻塞

    int sem_trywait(sem_t *sem); 尝试加锁, 不阻塞, 直接返回

    int sem_timedwait(sem_t *sem, const struct timespec *abs_timeout); 限时加锁

    解锁int sem_post(sem_t *sem);

    (4) 使用信号量实现生产者, 消费者模型

    #include <stdio.h>
    #include <unistd.h>
    #include <stdlib.h>
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <string.h>
    #include <pthread.h>
    #include <semaphore.h>
    
    sem_t produce_sem;
    sem_t custom_sem;
    
    typedef struct node {
        int data;
        struct node *next;
    }Node;
    
    Node *head = NULL;
    
    void* producer(void *arg) {
        while (1) {
            sem_wait(&produce_sem);
            Node *node = (Node *)malloc(sizeof(Node));
            node->data = rand() % 1000;
            node->next = head;
            head = node;
            printf("++++生产者: %lu, %d
    ", pthread_self(), node->data);
            sem_post(&custom_sem);
            sleep(rand()%5);
        }
        return NULL;
    }
    
    void* customer(void *arg) {
        while (1) {
            sem_wait(&custom_sem);
            Node *del = head;
            head = head->next;
            printf("----消费者: %lu, %d
    ", pthread_self(), del->data);
            free(del);
            sem_post(&produce_sem);
            sleep(rand()%5);
        }
        return NULL;
    }
    
    int main(int argc, const char *argv[]) {
        pthread_t thid[2];
        // 初始化信号量
        sem_init(&produce_sem, 0, 4);
        sem_init(&custom_sem, 0, 0);
        
        pthread_create(&thid[0], NULL, producer, NULL);
        pthread_create(&thid[1], NULL, customer, NULL);
    
        for (int i = 0; i < 2; i++) {
            pthread_join(thid[i], NULL);
        }
        
        sem_destroy(&produce_sem);
        sem_destroy(&custom_sem);
    
        return 0;
    }
    
    
  • 相关阅读:
    写了一个具有future接口的rust测试代码
    lua:写了个基于协程的task调度库
    最近阅读
    电视投屏
    树莓派 系统备份
    Kindle支持的文件格式
    树莓派 more
    用google translate大文件
    NFC 大电池 高性价比手机
    rust debug之基于pdb
  • 原文地址:https://www.cnblogs.com/hesper/p/10739006.html
Copyright © 2011-2022 走看看