• Linux 信号量函数介绍


    头文件:#include <semaphore.h>
    链接库 -pthread
    函数原型:
    int sem_init(sem_t *sem, int pshared, unsigned int value);
    参数说明:
    a. sem为指向未初始化信号量结构的一个指针
    b. pshared参数表示这个信号量是在进程的线程之间共享,还是在进程之间共享。
        如果pshared的值为0,那么这个信号量会在进程的线程之间共享,并且应该位于对所有线程都可见的某个地址
        如果pshared非零,那么这个信号量将在进程之间共享,并且应该位于共享内存的某个区域(参见shm_open(3)、
    mmap(2)和shmget(2))。(因为fork(2)创建的子进程会继承父进程的内存映射,所以它也可以获取信号量)。
    任何可以访问共享内存区域的进程都可以使用sem_post(3)、sem_wait(3)等对这个信号量进行操作。 c. value指定信号量的初始值 功能: 初始化信号量 返回值:成功返回0,失败返回-1
    函数原型:
    int sem_destroy(sem_t *sem);
    参数说明:
    sem为通过sem_init(3)初始化的信号量
    功能:
    释放信号量
    返回值:成功返回0,失败返回-1
    函数原型:
    int sem_post(sem_t *sem);
    参数说明:
    sem为通过sem_init(3)初始化的信号量
    功能:
    sem_post函数的作用是给信号量的值加上一个“1”,它是一个“原子操作”---即同时对同一个信号量做加“1”操作的两个线程是不会冲突的;
    而同 时对同一个文件进行读、加和写操作的两个程序就有可能会引起冲突。信号量的值永远会正确地加一个“2”--因为有两个线程试图改变它。 返回值:成功返回0,失败返回-1
    函数原型:
    int sem_wait(sem_t *sem);
    参数说明:
    sem为通过sem_init(3)初始化的信号量
    功能:
    sem_wait函数也是一个原子操作,它的作用是从信号量的值减去一个“1”,但它永远会先等待该信号量为一个非零值才开始做减法。
    也就是说,如果你对 一个值为2的信号量调用sem_wait(),线程将会继续执行,介信号量的值将减到1。如果对一个值为0的信号量调用sem_wait(),
    这个函数就 会地等待直到有其它线程增加了这个值使它不再是0为止。如果有两个线程都在sem_wait()中等待同一个信号量变成非零值, 那么当它被第三个线程增加 一个“
    1”时,等待线程中只有一个能够对信号量做减法并继续执行,另一个还将处于等待状态。 返回值:成功返回0,失败返回-1
  • 相关阅读:
    Java:类加载器(ClassLoader)
    Java 并发:Executor
    Java 并发:线程中断-interrupt
    UNIX IPC: POSIX 消息队列 与 信号
    Java与C++区别:重载(Overloading)
    UNIX IPC: POSIX 消息队列
    PAT 1078. Hashing
    PAT 1032. Sharing
    回顾经典问题算法:LIS, LCS-(DP类别)
    url编码模块
  • 原文地址:https://www.cnblogs.com/zhanggaofeng/p/14315087.html
Copyright © 2020-2023  润新知