首页
学习
活动
专区
工具
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信号量及函数

信号量的概念 信号量,或称信号灯,其原理是一种数据操作锁的概念,本身不具备数据交换的功能,它负责协调各个进程,保证保证两个或多个关键代码段不被并发调用,确保公共资源的合理使用。...在信号的实际应用中,是不能只定义一个信号量的,而只能定义一个信号量集,其中包含一组信号量,同一信号量集中的信号量使用同一个引用ID,这样的设置是为了多个资源或同步操作的需要。...setval error"); } // get some information about the semaphore and the limit of semaphore in Linux...struct sem_undo is 1 the maximum semaphore value is 32767 now free the resource remove sem okt 参考: 《精通Linux...C编程》- 程国钢 《Linux C编程完全解密》- 闫敬 吴淑坤

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

    信号量——Linux并发之魂

    引言 今天,我们继续学习Linux线程本分,在Linux条件变量中,我们对条件变量的做了详细的说明,今天我们要利用条件变量来引出我们的另一个话题——信号量内容的学习。...所以,前辈大佬们给出了一种解决方案——信号量。 3.信号量 3.1什么是信号量 信号量的本质是一把计数器,一把衡量临界资源多少的计数器。只要拥有信号量,就在未来一定能够拥有临界资源的一部分。...3.2信号量的相关接口 如上这些借口如果调用成功的话,返回0;调用失败的话,返回-1,并且错误原因被设置。 我们知道信号量的本质是一把计数器,所以信号量必须可以进行递增和递减的操作。...所以消费者可以成功申请到数据资源信号量,然后消费数据。但不知不觉,队列中的剩余空间多了一份,所以应对剩余空间资源的信号量进行V操作。 若队列满时,剩余空间信号量为0,生产者申请信号量失败。...此时,数据资源信号量为满,消费者可以申请到信号量,从而进行操作。所以必须消费者先运行。 若队列空时,数据资源信号量为0,消费者申请信号量失败。

    10910

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

    若sem<=0,则从阻塞队列中唤醒一个阻塞在该信号量上的线程,然后再返回原线程(调用ν操作的线程)继续执行。...Linux多进程访问共享资源时,需要按下列步骤进行操作: (1)检测控制这个资源的信号量的值。 (2)如果信号量是正数,就可以使用这个资源。进程将信号量的值“减 1”,表示当前进程占用了一份资源。...也就是说,如果你对一个值为2的信号量调用sem_wait(),线程将会继续执行,信号量的值将减到1。...如果对一个值为0的信号量调用sem_wait(), 这个函数就会地等待直到有其它线程增加了这个值使它不再是0为止。...pthread_create(&smk_1, 0, smoker, 1); pthread_create(&smk_2, 0, smoker, 2); while(1); } Linux

    2.9K30

    Linux线程编程之信号量

    hello pthread jjjkj the input words is 5 jjkl;j the input words is 6 end over 注意: 这里在Linux...不过在这之前还是要稍微介绍一下什么是线程信号量,其实这个跟进程通信有点类似——Linux进程编程----syslog的使用和进程间通信的介绍(六): a、那么什么是信号量呢?...b、信号量的类型: 二进制信号量(binary semaphore):只允许信号量取0或1值,其同时只能被一个线程获取。...整型信号量(integer semaphore):信号量取值是整数,它可以被多个线程同时获得,直到信号量的值变为0。...当信号量被释放一个,值被加一后,系统自动从等待队列中唤醒一个等待中的线程,让其获得信号量,同时信号量再减一。

    1.6K20

    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)。...但是,从Linux内核2.6.37版本之后,上面的函数和宏已经不存在。这是为什么呢?因为大家发现在Linux内核的设计实现中通常使用互斥信号量,而不会使用信号量。...如果一个进程想要释放内核信号量,会调用up()函数。...所以,只有异常处理程序,尤其是系统调用服务例程可以调用down()函数。基于这个原因,Linux还提供了其它版本的请求信号量的函数: down_trylock() 可以被中断和延时函数调用

    1.6K20

    Linux系统中的信号量机制

    ; }; 在linux中,信号量用上述结构体表示,我们可以通过该结构体定义一个信号量。...也可以用两个宏来定义和初始化信号量的值为1或0: DECLARE_MUTEX(name) : 定义信号量name并初始化为1 DECLARE_MUTEX_LOCKED(name) : 定义信号量name...semaphore *sem); //初始化信号量的值为0 3、信号量的原子操作: p操作: void down(struct semaphore *sem); //用来获取信号量,如果信号量值大于或等于...0,获取信号量,否则进入睡眠状态,睡眠状态不可唤醒 void down_interruptible(struct semephore *sem); //用来获取信号量,如果信号量大于或等于0,获取信号量...void down_trylock(struct semaphore *sem); //试图获取信号量,如果信号量已被其他进程获取,则立刻返回非零值,调用者不会睡眠 v操作: void up(struct

    2.6K60

    python调用调用Linux命令

    如何调用Linux命令 下面代码演示了调用一个shell命令, 其中,命令的输出会存储到result变量中, 而命令的返回值,则存储到exitcode中,由此可见,调用shell命令还是很方便的: import...ftp.login('user','password') ftp.retrbinary('RETR readme.txt', open("readme.txt", "wb").write) ftp.quit() 调用...编译成动态库: g++ -fPIC api.cpp -o api.so -shared -I/usr/include/python2.7 -I/usr/lib/python2.7/config 在python中调用...add函数: import ctypes plib = ctypes.CDLL('/tmp/api.so') print "result: %d" %(plib.add(1,2)) 系统调用 虽然需求好像有点...“过份”,但是强大的python是可以调用诸如ioctl这类的Linux系统调用的, 以下的例子是让蜂鸣器响: import fcntl fd = open('/dev/pwm', 'r') fcntl.ioctl

    5.2K20

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

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

    1.3K20

    Linux 的进程间通信:信号量

    在这里首先强调一下,Linux系统中的semaphore信号量和signal信号是完全不同的两个概念。我们将在其它文章中详细讲解信号signal。本文可以帮你学会: 什么是XSI信号量?...但是从本质上讲,信号量实际上是实现了一套可以实现类似锁功能的原语,我们不仅可以用它实现锁,还可以实现其它行为,比如经典的PV操作。 Linux环境下主要实现的信号量有两种。...文件中包涵4个限制值,它们分别的含义是: SEMMSL:一个信号量集(semaphore set)中,最多可以有多少个信号量。这个限制实际上就是semget调用的第二个参数的个数上限。...SEMMNS:系统中在所有信号量集中最多可以有多少个信号量。 SEMOPM:可以使用semop系统调用指定的操作数限制。这个实际上是semop调用中,第二个参数的结构体中的sem_op的数字上限。...最后 希望这些内容对大家进一步深入了解Linux信号量。如果有相关问题,可以在我的微博、微信或者博客上联系我。 大家好,我是Zorro!

    6.7K01

    Linux】多线程 之 POSIX信号量

    信号量的工作机制 信号量机制类似于看电影买票,一种资源的预订机制 申请信号量成功,相当于预定了一部分资源 判断条件是否满足,决定了后续行为 信号量已经是资源的计数器,申请信号量成功,本身就表明资源可用...输入 man sem_destroy 对已经初始化的信号量进行销毁 sem_wait ——申请信号量 输入 man sem_wait 进行申请信号量的操作,使信号量的值减1 sem_post...——释放信号量 输入 man sem_post 进行释放信号量的操作,使信号量的值加1 4....) 析构 由于在构造时,对信号量进行初始化,所以需要销毁信号量 push ——生产 要生产之前要保证符合条件,才能够进行生产,所以要进行P操作——申请信号量 在使用信号量时,是不需要判断的 因为信号量是一把计数器...当tail达到多开一个空间位置,实际上相当于再次回到head开头的位置 所以使用%=,模拟环形队列 ---- 将 sem_wait 和sem_post借助 函数 P和V完成封装 再次使用时,只需调用

    34550

    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

    LinuxLinux系统调用

    Linux系统调用 前言 操作系统——管理计算机硬件与软件资源的软件,是用户和系统交互的操作接口,为它上面运行的程序提供服务。...例如LinuxLinux操作系统——基于Linux内核的操作系统。通常由Linux内核、shell(特殊的应用程序,提供运行其他程序的接口)、文件系统和应用程序组成。...Linux的运行空间: Linux的运行空间:内核空间+用户空间 ---- 内核空间——存放的是整个内核代码和所有内核模块,以及内核所维护的数据。 用户空间——用户程序的代码和数据。...---- 系统调用的实现 通过软件中断实现。 **软件中断:**它是通过软件指令触发的中断。Linux系统内核响应软件中断,从用户态切换到内核态,执行相应的系统调用。...调用相应的执行程序来处理系统调用。 从系统调用返回。 系统调用号: 每个系统调用被赋予一个系统调用号,与具体的系统调用相关联。

    27.9K10

    Linux 系统调用

    Linux 中,系统调用是用户空间访问内核的唯一手段﹔除异常和陷入外,它们是内核唯一的合法入口。实际上,其他的像设备文件和/proc之类的方式,最终也还是要通过系统调用进行访问的。...而有趣的是,Linux 提供的系统调用却比大部分操作系统都少得多。 要访问系统调用(在 Linux 中常称作 syscall),通常通过C库中定义的函数调用来进行。...系统调用在出现错误的时候C库会把错误码写人errno全局变量。通过调用perror()库函数,可以把该变量翻译成用户可以理解的错误字符串。 在 Linux 中,每个系统调用被赋予一个系统调用号。...假设系统调用在内核空间定义为 sys_ioctl,那么该系统调用的用户空间接口为 ioctl Linux kernel-5.18.8 有 440 个系统调用,这些系统调用讲究通用性,一旦固定,很少修改,...保证 Linux 系统的稳定性和兼容性。

    9.8K20

    Linux进程间通信【消息队列、信号量

    int msgflg 位图,可以设置消息队列的创建方式及创建权限 与 共享内存 的 shmget 可以说是十分相似了,关于 ftok 函数计算 key 值,这里就不再阐述,可以在这篇文章中学习 《Linux...**此时的 信号量 可以设为 1,确保 只允许一个执行流进行访问,这种 信号量 被称为 二元信号量,常用来实现 互斥 综上所述,信号量本质上就是 计数器 count,所谓的 P 操作(申请)就是在对 count...2 int semnum 表示对信号量集中的第 semnum 个信号量作操作 参数3 int cmd 控制信号量的具体动作,同样是位图 参数4 ......多线程 时,也会使用 POSIX 中的 信号量 实现 互斥,相比之下,POSIX 版的信号量操作要简单得多,同时应用也更为广泛 因为 信号量 需要被多个独立进程看到,所以 信号量 本身也是 临界资源,...假设想访问具体 ipc 中的资源,可以通过 ipc_id_arr[n] 强转为对应类型指针,再通过 -> 访问其中的其他资源 以上方法就是 多态,通过父类指针,访问成员 ---- 总结 以上就是本次关于 Linux

    51430

    Linux内核34-读写信号量

    1 读/写信号量的工作原理 读/写信号量和读/写自旋锁类似,不同的地方是进程在等待读/写信号量的时候处于挂起状态,而在等待读/写自旋锁的时候是处于忙等待,也就是自旋的状态中。...因此,对于读/写信号量来说,写操作的时候,既不可以进行读操作,也不可以进行写操作。读/写信号量提高了内核中的并发数量,也同时提高了系统的整体性能。...内核严格按照先进先出(FIFO)的原则处理等待读/写信号量的进程。读进程或者写进程一旦请求信号量失败,就被写到信号量等待队列的队尾。当信号量被释放后,队列中的第一个进程先被执行,因为它先被唤醒。...down_read() 和 down_write()函数分别用来请求读信号量和写信号量。同理,up_read()和 up_write()函数分别用来释放读信号量和写信号量。...最后,还有一个重要的函数,downgrade_write(),用于写进程使用完写信号量之后,自动将其转换成一个读信号量

    1.4K10

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

    信号量是什么 信号量是一种计数器,用来控制对多个进程/线程共享的资源进行访问。常和锁一同使用。 在某个进程/线程正在对某个资源进行访问时,信号量可以阻止另一个进程/线程去打扰。...这样看来,一个是Unix 的标准之一(另一个标准是Open Group),一个是Unix众多版本的分支之一(其他的分支还有Linux跟BSD),应该来说,Posix标准正变得越来越流行,很多厂家开始采用这一标准...2、从使用的角度,System V 信号量的使用比较复杂,而 POSIX 信号量使用起来相对简单。 3、对 POSIX 来说,信号量是个非负整数。...而 System V 信号量则是一个或多个信号量的集合,它对应的是一个信号量结构体,这个结构体是为 System V IPC 服务的,信号量只不过是它的一部分。...GETTALL:用于获取集合中所有的信号量的值,存放在semun联合体的array中。 GETPID:返回最后一次调用semop的PID。 GETVAL:返回集合中某个信号量的值。

    1.6K10
    领券