进程以及线程间的通信

pipe管道函数

1、管道两端都是正常的, 如果管道里没有数据, read函数是阻塞的,

   如果写端断开或者出现异常, read函数解除阻塞,返回值为0

2、如果读端异常, 写端继续往管道中写数据,内核会发送SIGPIPE信号,

   该信号的默认操作是程序退出, 所以写端一定要捕捉  SIGPIPE信号

文件锁

struct flock
{
    short    l_type;//锁的类型 F_RDLCK,F_WRLCK(排他锁),F_UNLCK(清除锁)
    short    l_whence;//锁的范围 SEEK_SET, SEEK_CUR, SEEK_END 文件开头,当前位置,结尾。基准位置
    off_t  l_start;//相对于基准的偏移值。定义了锁的起始
    off_t  l_len;//锁的字节数
    pid_t    l_pid;//获取哪个进程处于阻塞。仅仅当(set by F_GETLK and F_OFD_GETLK)
};

shmget共享内存函数

shmget(key_t key,   size_t size,   int shmflg)

IPC_CREAT:当shmflg&IPC_CREAT为真时,如果内核中不存在键值与key相等的共享内存,则新建一个共享内存;如果存在这样的共享内存,返回此共享内存的标识符。

IPC_CREAT|IPC_EXCL:如果内核中不存在键值 与key相等的共享内存,则新建一个共享内存;如果存在这样的共享内存则报错。

shmat函数

shmat(int shmid, const void *shmaddr, int shmflg);

第一个参数 shmid

shmget函数 的返回值,共享内存标识符

第二参数 shmaddr

指定共享内存出现在进程内存地址的什么位置

直接指定为NULL让内核自己决定一个合适的地址位置

第三个参数 shmflag

0:读写模式

SHM_RDONLY:为只读模式

返回值

附加好的共享内存地址

消息队列

“消息”是在两台计算机间传送的数据单位。消息可以非常简单,例如只包含文本字符串;也可以更复杂,可能包含嵌入对象

消息被发送到队列中。“消息队列”是在消息的传输过程中保存消息的容器。消息队列管理器在将消息从它的源中继到它的目标时充当中间人。队列的主要目的是提供路由并保证消息的传递;如果发送消息时接收者不可用,消息队列会保留消息,直到可以成功地传递它。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值