上一篇:Linux中判定c盘是固态硬碟或机械硬碟怎么做下一篇:Linux中文件的切分与合并方式是哪些,如何做
这篇文章给你们介绍了“Linux中进程间通讯有多少方法,分别是哪些”的相关知识,讲解详尽,步骤过程清晰unix系统 进程间通信,有一定的借鉴学习价值,因而分享给你们做个参考linux虚拟机,感兴趣的同学接出来一起追随小编瞧瞧吧。
进程的概念
进程是操作系统的概念,每每我们执行一个程序时,对于操作系统来讲就创建了一个进程,在这个过程中,伴随着资源的分配和释放。可以觉得进程是一个程序的一次执行过程。
进程通讯的概念
进程用户空间是互相独立的,通常而言是不能互相访问的。但好多情况下进程间须要互相通信,来完成系统的某项功能。进程通过与内核及其它进程之间的互相通信来协调它们的行为。
进程通讯的应用场景
数据传输:一个进程须要将它的数据发送给另一个进程,发送的数据量在一个字节到几兆字节之间。
共享数据:多个进程想要操作共享数据,一个进程对共享数据的更改,别的进程应当立即听到。
通知风波:一个进程须要向另一个或一组进程发送消息,通知它(它们)发生了某种风波(如进程中止时要通知父进程)。
资源共享:多个进程之间共享同样的资源。为了作到这一点,须要内核提供锁和同步机制。
进程控制:有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望才能拦截另一个进程的所有深陷和异常,并才能及时晓得它的状态改变。
进程通讯的形式1.管线
管线分为有名管线和无名管线
无名管线是一种半双工的通讯方法,数据只能双向流动,并且只能在具有亲缘关系的进程间使用.进程的亲缘关系通常指的是父女关系。无明管线通常用于两个不同进程之间的通讯。当一个进程创建了一个管线,并调用fork创建自己的一个子进程后,父进程关掉读管线端,子进程关掉写管线端,这样提供了两个进程之间数据流动的一种形式。
有名管线也是一种半双工的通讯方法,并且它容许无亲缘关系进程间的通讯。
2.讯号量
讯号量是一个计数器,可以拿来控制多个线程对共享资源的访问.,它不是用于交换大批数据,而用于多线程之间的同步.它常作为一种锁机制,避免某进程在访问资源时其它进程也访问该资源.因而,主要作为进程间以及同一个进程内不同线程之间的同步手段.
Linux提供了一组悉心设计的讯号量插口来对讯号进行操作,它们不只是针对二补码讯号量,下边将会对这种函数进行介绍,但请注意,这种函数都是拿来对成组的讯号量值进行操作的。它们申明在头文件sys/sem.h中。
semget函数
它的作用是创建一个新讯号量或取得一个已有讯号量
semop函数
它的作用是改变讯号量的值
semctl函数
该函数拿来直接控制讯号量信息
3.讯号
讯号是一种比较复杂的通讯方法,用于通知接收进程某个风波早已发生.
4.消息队列
消息队列是消息的数组,储存在内核中并由消息队列标示符标示.消息队列克服了讯号传递信息少,管线只能承载无格式字节流以及缓冲区大小受限等特征.消息队列是UNIX下不同进程之间可实现共享资源的一种机制,UNIX容许不同进程将低格的数据流以消息队列方式发送给任意进程.对消息队列具有操作权限的进程都可以使用msget完成对消息队列的操作控制.通过使用消息类型,进程可以按任何次序读信息,或为消息安排优先级次序.
5.共享显存
共享显存就是映射一段能被其他进程所访问的显存,这段共享显存由一个进程创建,但多个进程都可以访问.共享显存是最快的IPC(进程间通讯)方法,它是针对其它进程间通讯形式运行效率低而专门设计的.它常常与其他通讯机制,如讯号量,配合使用,来实现进程间的同步与通讯.
6.套接字
socket,即套接字是一种通讯机制,凭着这些机制unix系统 进程间通信,顾客/服务器(即要进行通讯的进程)系统的开发工作既可以在本地单机上进行,也可以跨网路进行。也就是说它可以让不在同一台计算机但通过网路联接计算机上的进程进行通讯。也由于这样,套接字明晰地将顾客端和服务器区分开来。
套接字的特点由3个属性确定,它们分别是:域、类型和合同。
可用于不同及其间的进程通讯
关于“Linux中进程间通讯有多少方法,分别是哪些”就介绍到这了,假如你们感觉不错可以参考了解瞧瞧,假如想要了解更多,欢迎关注群英网路linux操作系统版本,小编每天都会为你们更新不同的知识。
文章评论