(一)进程的概念
进程是操作系统的概念,每当我们执行一个程序时,对于操作系统来讲就是创建一个进程,在这个
过程中伴随着资源的分配和释放,可以认为进程是一个程序的一次执行过程。
(二)进程间通信的概念
进程用户空间是相互独立的,一般而言是不能相互访问的,但很多情况下进程间需要相互通信
来完成系统的某项功能,进程通过与内核及其他进程之间的相互通信来协调他们的行为。
(三)进程通信的应用场景
数据传输:一个进程需要将它的数据发送给另外一个进程,发送的数据量在一个字节到几兆字节之间。
共享数据:多个进程想要操作共享数据,一个进程对共享数据的修改,别的进程立刻能看到。
通知事件:一个进程需要向另一个或一组进程发送消息,通知他们发生了某种事件,如进程终止时
要通知父进程。
资源共享:多个进程之间共享同样的资源,为了做到这一点,需要内核提供锁和同步机制。
进程控制:有些进程希望完全控制另一个进程的执行如debug进程,此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态变化。
进程的通信方式:
管道:
普通管道:只能在父子或者兄弟间使用且是单工。
流管道:只能在父子或兄弟进程间使用,可以双向传输。
命名管道:可以在不相关的进程之间进行通讯
信号量:信号量是一种计数器,可以用来控制多个进程对共享资源的访问,互斥信号量常作为一种锁机制,防止某进程正在访问共享资源时,其他进程也访问该资源,主要作为进程间及同一进程间不同线程之间的同步手段。
消息队列:消息队列是由消息的链表,存放在内核中并由消息队列标识符标识,消息队列克服了信号传递信息少管道只能承载无格式字节流以及缓冲区大小受限制等缺点。
信号:信号是一种比较复杂的通信方式,用于通知接收进程某个事件已经发生。
共享内存:共享内存就是映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问,共享内存是最快的ipc方式,他是针对其他进程间通信方式运行效率低而专门设计的,它往往与其他通信机制配合使用。
套接字:套接口也是一种进程间通信的机制,与其他通信机制不同的是,他可用于不同机器间的进程通信。
