Lesson2--进程通讯

linux进程间通信方式包括:

1.管道(pipe)和有名管道(FIFO)
2.信号(signal)
3.消息队列
4.共享内存
5.信号量
6.套接字(socket)


管道通信
 单向的、先进先出
 一个进程(写进程)在管道的尾部写入数据,另一个进程(读进程)从管道头部读出数据

 无名管道只能用于父子进程间通信,有名管道用于同一系统中的任意2个进程间的通信

无名管道由pipe()函数创建
 int pipe(int filedis[2]);
 当一个管道建立时,它会创建2个文件描述符
 filedis[0]用于读管道,filedis[1]用于写管道
 关闭管道--close函数

 

必须在调用fork()前调用pipe(),否则子进程将不会继承文件描述符

 

 

命名管道

#include <sys/types.h>
#include <sys/stat.h>

int mkfifo(const char *pathname, mode_t omde)
pathname: FIFO文件名
mode:  属性
创建了一个FIFO就可以用open打开它,一般的文件访问函数(close、read、write等)都可以用于FIFO

 

 

 

 

信号通信

信号(signal)
 某些按键
 硬件中断
 kill函数将信号发送给
 另一个进程
 kill命令发送信号

信号处理:
 忽略此信号--SIGKILL和这2个信号们向超级用户提供了一种终止或停止进程的方法(SIG_IGN)
 执行用户希望的动作--发生某信号时,调用一个用户函数,函数中执行用户希望的处理(函数

名)
 执行系统默认动作--默认动作时终止该进程(SIG_DFL)

#include <signal.h>
void (*signal (int signo, void (*func)(int)))(int)

void (*)(int)
signal (int signo, void (*func)(int))
拆分完为2个函数指针

typedef void (*sighandler_t)(int)
sighandler_t signal(int signum, sighandler_t handler)

Func可能的值:1.SIG_IGN;2.SIG_DFL;3.信号处理函数名

信号发生函数:kill、raise、alarm

 

kill [-s signal] pid 向指定的进程发送指定的信号

 


共享内存通讯

共享内存:被多个进程共享的一部分物理内存。

实现分两个步骤:
 1.创建共享内存,使用shmget函数
 2.映射共享内存,将这段创建的共享内存映射到具体的进程空间去,使用shmat函数

int shmget(key_t key, int size, int shmflg)
 key
 取:IPC_PRIVATE--创建一块新的共享内存
成功返回共享内存标识符;如果失败,返回-1

int shmat(int shmid, char *shmaddr, int flag)

 shmid
 shmget函数返回的共享存储标识符
 flag
 决定以什么方式来确定映射地址(通常为0)
成功则返回共享内存映射到进程中的地址,失败则返回-1

int shmdt(char *shmaddr)
当进程不再需要共享内存时,需要把它从进程地址空间中脱离

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值