首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux并发(POSIX信号量

System-V的信号量是老古董,除非万不得已,否则我们一般用POSIX信号量,好用、简单、靠谱。...拓展: POSIX信号量分为两种,分别是POSIX无名信号量和POSIX有名信号量,这两种信号量比之前介绍的system-V的信号量机制要简洁,虽然没有后者的应用范围那么广泛(尤其在一些老系统中,因为system-V...的信号量机制要更古老一些),但是POSIX良好的设计使得他们更具吸引力。...POSIX有名信号量的一般使用步骤是: 1,使用sem_open( )来创建或者打开一个有名信号量。 2,使用sem_wait( )和sem_post( )来分别进行P操作和V操作。...POSIX无名信号量的一般使用步骤是: 1,在这些线程都能访问到的区域定义这种变量(比如全局变量),类型是sem_t。 2,在任何线程使用它之前,用sem_init( )初始化他。

2.4K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    信号量——Linux并发之魂

    引言 今天,我们继续学习Linux线程本分,在Linux条件变量中,我们对条件变量的做了详细的说明,今天我们要利用条件变量来引出我们的另一个话题——信号量内容的学习。...所以,前辈大佬们给出了一种解决方案——信号量。 3.信号量 3.1什么是信号量 信号量的本质是一把计数器,一把衡量临界资源多少的计数器。只要拥有信号量,就在未来一定能够拥有临界资源的一部分。...信号量信号量是表征临界资源中资源数目的。 1.对于生产者而言,看中的是队列中的剩余空间——空间资源定义一个信号量。 2.对于消费者而言,看中的是队列中的数据——数据资源定义一个信号量。...所以消费者可以成功申请到数据资源信号量,然后消费数据。但不知不觉,队列中的剩余空间多了一份,所以应对剩余空间资源的信号量进行V操作。 若队列满时,剩余空间信号量为0,生产者申请信号量失败。...此时,数据资源信号量为满,消费者可以申请到信号量,从而进行操作。所以必须消费者先运行。 若队列空时,数据资源信号量为0,消费者申请信号量失败。

    10910

    Linux内核编程--信号量机制

    Linux多进程访问共享资源时,需要按下列步骤进行操作: (1)检测控制这个资源的信号量的值。 (2)如果信号量是正数,就可以使用这个资源。进程将信号量的值“减 1”,表示当前进程占用了一份资源。...int value); 参数说明: a. sem为指向未初始化信号量结构的一个指针 b. pshared参数表示这个信号量是在进程的线程之间共享,还是在进程之间共享。...c. value指定信号量的初始值 功能: 初始化信号量 返回值:成功返回0,失败返回-1 3.销毁信号量: int sem_destroy(sem_t *sem); 参数说明: sem为通过sem_init...(3)初始化信号量 功能: 释放信号量 返回值:成功返回0,失败返回-1 4.给信号量“加1” int sem_post(sem_t *sem); 参数说明: sem为通过sem_init初始化信号量...六,具体的编程练习 信号量编程步骤: 1.定义信号量:sem_t 2.初始化信号量:sem_init(sem_t *); 3.加锁:sem_wait() 4.执行业务逻辑代码 5.解锁:sem_post

    2.9K30

    Linux进程通信之信号量

    Linux进程通信之信号量 概念(自行百度): 信号量(Semaphore),有时被称为信号灯,是在多线程环境下使用的一种设施,是可以用来保证两个或多个关键代码段不被并发调用。...在进入一个关键代码段之前,线程必须获取一个信号量;一旦该关键代码段完成了,那么该线程必须释放信号量。其它想进入该关键代码段的线程必须等待直到第一个线程释放信号量。...PV原语: 信号量有两个原子操作:P操作和V操作,具体意义也要分信号量类型的情况 P() : sem减1 V() : sem加1 分类(以了解的) 二进制信号量(0和1) 信号集(集合数组) 为什么要使用信号量...ret -ne 20000 ] then echo "$ret有问题" fi echo -e "-->\c" let "int++" done 执行shell 查看结果 发现并没有出现没有使用信号量之前数据错乱的情况...,使用ipcs 命令查看,信号量已存在 注意 使用完信号量之后,要使用sem_remove函数删掉信号量,否则会造成系统资源浪费

    1.8K30

    Linux内核33-信号量

    事实上,Linux提供了两类信号量: 内核使用的信号量 用户态使用的信号量(遵循System V IPC信号量要求) 在本文中,我们集中研究内核信号量,至于进程间通信使用的信号量以后再分析。...虽然信号量可以支持很大的count,但是在linux内核中,大部分情况下还是使用信号量的一种特殊形式,也就是互斥信号量(MUTEX)。...另外,还分别有两个静态初始化方法: DECLARE_MUTEX DECLARE_MUTEX_LOCKED 这两个宏的作用和上面的初始化函数一致,但是静态分配信号量变量。...当然了,count还可以被初始化为一个整数值n(n大于1),这样的话,可以允许多达n个进程并发访问资源。 但是,从Linux内核2.6.37版本之后,上面的函数和宏已经不存在。这是为什么呢?...基于这个原因,Linux还提供了其它版本的请求信号量的函数: down_trylock() 可以被中断和延时函数调用。

    1.6K20

    Linux系统中的信号量机制

    ; }; 在linux中,信号量用上述结构体表示,我们可以通过该结构体定义一个信号量。...2、信号量初始化: 可用void sema_init(struct semaphore *sem, int val);直接创建,其中val为信号量初值。...也可以用两个宏来定义和初始化信号量的值为1或0: DECLARE_MUTEX(name) : 定义信号量name并初始化为1 DECLARE_MUTEX_LOCKED(name) : 定义信号量name...并初始化为0 还可以用下面的函数初始化: void init_MUTEX(struct semaphore *sem); //初始化信号量的值为1 void init_MUTEX_LOCKED(struct...semaphore *sem); //初始化信号量的值为0 3、信号量的原子操作: p操作: void down(struct semaphore *sem); //用来获取信号量,如果信号量值大于或等于

    2.6K60

    Linux进程间通信:信号量(一)

    前提知识 在介绍信号量之前,先来看看一些概念和一些简单的前提知识: 进程间通信的前提是让不同的进程看到同一份资源。...我们使用这个例子来转化成对信号量的理解: 影厅就是一个临界区,每个座位就是一个个临界资源。也就是说这个临界区中有100个临界资源。...小张就是一个进程,进程去访问临界资源的时候,先是通过信号量去“预定”资源。需要注意的是进程拿到了这个临界资源的访问权不代表这可以马上去访问。...特别的,当信号量sem等于1的时候,这意味共享资源的作为一整个资源被使用的。这种信号量称为二元信号量,通过互斥功能保护公共资源!...所有的进程在访问公共资源前,都必须先申请信号量,而申请信号量的前提,是让不同进程看到同一个信号量,因此信号量本身就是一个公共资源,这意味着信号量必须保证自己 的安全性!

    1.3K20

    Linux 的进程间通信:信号量

    在这里首先强调一下,Linux系统中的semaphore信号量和signal信号是完全不同的两个概念。我们将在其它文章中详细讲解信号signal。本文可以帮你学会: 什么是XSI信号量?...但是从本质上讲,信号量实际上是实现了一套可以实现类似锁功能的原语,我们不仅可以用它实现锁,还可以实现其它行为,比如经典的PV操作。 Linux环境下主要实现的信号量有两种。...以上就是信号量定义的原语意义。如果用它实现类似互斥锁的操作,那么我们就可以初始化一个默认计数器值为1的的信号量,当有人进行加锁操作的时候对其减1,解锁操作对其加1。...匿名信号量使用sem_init进行初始化,使用sem_destroy()销毁。操作方法跟命名信号量一样。...匿名内存的初始化方法跟sem_open不一样,sem_init要求对一段已有内存进行初始化,而不是在/dev/shm下产生一个文件。

    6.7K01

    Linux】多线程 之 POSIX信号量

    认识接口 POSIX信号量 和system V 信号量 作用相同,都是用于同步操作,达到无冲突的访问共享资源目的,但POSIX可以用于线程间同步 ---- sem_init ——初始化信号量 输入 man...sem_init sem :表示信号量 pshared : 0表示线程间共享 非零表示进程间共享 value : 信号量初始值 (计数器值初始化为多少) sem_destroy——销毁信号量...输入 man sem_destroy 对已经初始化信号量进行销毁 sem_wait ——申请信号量 输入 man sem_wait 进行申请信号量的操作,使信号量的值减1 sem_post...,空间信号量只有生产者关心 构造 将环形队列ring大小和_cap(容量)初始化为N 0表示线程间共享,将数据信号量 初始化为0,将空间信号量初始化为整个环形队列的容量 (对于两者的初始化值大小,在原理处都有详细解释...) 析构 由于在构造时,对信号量进行初始化,所以需要销毁信号量 push ——生产 要生产之前要保证符合条件,才能够进行生产,所以要进行P操作——申请信号量 在使用信号量时,是不需要判断的 因为信号量是一把计数器

    34250

    linux 进程通信-信号量(Semaphore)《Rice linux 学习开发》

    而Posix信号灯(线程同步)指的是单个计数信号灯 System V 信号灯由内核维护 信号量的使用规则 若信号量为正,则进程可使用该资源 若信号量为0,则进程阻塞等待,并将进程插入等待队列,直到该信号量的值大于...0从等待队列中执行进程请求 加锁操作:如果信号量大于0,则信号量-1;如果信号量为0,则挂起该进程,并将这个进程插入等待队列 解锁操作:如果等待队列中有进程则唤醒该进程,让它恢复运行,否则,信号量+1...信号量相关函数 semget()函数:创建新的信号量或取得已有的信号量 semop()函数:改变信号量的值,改变操作在sem_opa中,sem_opa是sumbuf结构体对象 semctl()函数:...控制信号量 例程 信号量例程请参考github的semaphore目录下semaphore.c。...github链接:https://github.com/RiceChen/Linux-process-communication.git,记得加个star。

    1.5K20

    Linux系统-初始化

    Linux系统相关内容,主要从以下几个方面来讲解: Linux系统-开关机 Linux系统-单用户模式 Linux系统-救援模式 Linux系统-僵尸&孤儿进程 Linux系统-systemd Linux...系统-logrotate Linux系统-发行版介绍 Linux系统-发行版rocky Linux系统-发行版ubuntu Linux系统-初始化(本章节) 其实我们只要熟悉某一种操作系统,其他系统的安装基本上就是一样的...为什么把初始化安装单独拿一小节来说呢,是因为我们运维的服务器是很多台,以后如果新安装或者重装以后完成一些初始化操作,我们可以将这个服务器快速完成系统安装然后投入到使用当中。...而我们初始化当中需要做的事情一般包括以下几个方面(具体以需求为准)。...初始化 1.主机名修改 hostnamectl set-hostname xxx 2.ip地址配置 3.host配置 3.防火墙关闭 systemctl stop firewalld systemctl

    5700

    信号量--System V信号量 与 Posix信号量

    信号量是什么 信号量是一种计数器,用来控制对多个进程/线程共享的资源进行访问。常和锁一同使用。 在某个进程/线程正在对某个资源进行访问时,信号量可以阻止另一个进程/线程去打扰。...这样看来,一个是Unix 的标准之一(另一个标准是Open Group),一个是Unix众多版本的分支之一(其他的分支还有Linux跟BSD),应该来说,Posix标准正变得越来越流行,很多厂家开始采用这一标准...2、从使用的角度,System V 信号量的使用比较复杂,而 POSIX 信号量使用起来相对简单。 3、对 POSIX 来说,信号量是个非负整数。...而 System V 信号量则是一个或多个信号量的集合,它对应的是一个信号量结构体,这个结构体是为 System V IPC 服务的,信号量只不过是它的一部分。...short sem_op; //信号量的操作 {正负零} short sem_flg; //信号量的操作标志 {NOWAIT} }; //sem_op取0表示将信号量设为睡眠状态,直到信号量的值为

    1.6K10

    Linux内核34-读写信号量

    1 读/写信号量的工作原理 读/写信号量和读/写自旋锁类似,不同的地方是进程在等待读/写信号量的时候处于挂起状态,而在等待读/写自旋锁的时候是处于忙等待,也就是自旋的状态中。...内核严格按照先进先出(FIFO)的原则处理等待读/写信号量的进程。读进程或者写进程一旦请求信号量失败,就被写到信号量等待队列的队尾。当信号量被释放后,队列中的第一个进程先被执行,因为它先被唤醒。...3 读/写信号量的有关API 初始化函数为 init_rwsem(),用其可以初始化一个rw_semaphore数据结构,将count设为0,wait_lock自旋锁设为未使用,wait_list设为空列表...down_read() 和 down_write()函数分别用来请求读信号量和写信号量。同理,up_read()和 up_write()函数分别用来释放读信号量和写信号量。...最后,还有一个重要的函数,downgrade_write(),用于写进程使用完写信号量之后,自动将其转换成一个读信号量

    1.4K10
    领券