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