自己总结了一些关于进程间通信的方式,内容不全或者有什么不足的请大家谅解。方便的话可以指点小弟一下,感激不尽。
Linux进程间的通信主要有:
一.管道通信
二.信号
三.共享内存
四.信号量
五.消息队列
六.套接字
一.管道
1.无名管道
特点:a.两个进程之间必须具有情缘关系;
b.这种方式的通信是单工的,具有固定的读写端。fd【0】和fd【1】分别是读写端;
使用函数:int pipe(int fd[【】);
2.有名管道
与无名管道不同的是两个进程间不需要情缘关系,可以是任意进程。管道的通信方式是通过类似于文件的读写,使用open()、read()、write()函数。
使用函数:int mkfifo(const char *filename, mode_t mode);
filename: 要创建的管道名
mode: 管道的访问权限
二.信号
信号是在软件层次上对中断机制的模拟。信号是异步的:一个进程不必通过任何操作来等待一个信号的到达。信号是进程间通信机制中唯一的异步通信机制。
进程可以通过3种方式来响应一个信号:
1.忽略信号
2.捕捉信号
3.执行默认信号
下面是常见的信号:
SIGHUP
SIGINT
SIGQOUIT
SIGILL
SIGFPE
SIGKILL
SIGKILL
SIGALARM
SIGSTOP
SIGTSTP
SIGCHLD
发送信号的函数:信号的发送int kill(pid_t pid, int sig)、信号的捕捉int rase(int sig);
设置信号函数:sighandler_t signal(int signum, sighandler_t hander)、sigaction();
其他函数:alarm()、puase();
三.共享内存
共享内存是一种最为高效的进程间通信,进程可以直接读写内存,而不需要进行任何数据的拷贝。
共享内存的使用步骤:
1.创建/打开共享内存
2.映射共享内存
3.撤销映射
3.删除共享内存
使用的函数:
创建共享内存:
int shmget(key_t key, int size, int shmflg);
key:共享内存的键值,进程可以通过键值来访问对应的共享内存;
size:设置共享内存的大小;
shmflg:设置共享内存的访问权限;
共享内存的映射:
char *shmat(int shmid, const void *shmaddr, int shmflg);
shmid:要映射到共享内存的标示符;
shmaddr:将共享内存映射到指定的地址;
shmflg:设置权限;
解除映射:
int shmdt(const void *shmaddr);
删除共享内存:
int shmctl(int shmid,int cmd, struct shmid_ds *buf);
四.信号量
同步和异步
同步:
使用函数:
初始化int sem_init(set_t *sem, int pshared, unsigned int value);
p操作:int sem_wait(sem_t *sem);
v操作:int sem_post(sem_t *sem);
互斥:主要用来保护临界资源
使用函数:
初始化锁:int pthread_mutex_init(pthread_mutex *mutex, pthread_mutexattr_t *attr);
申请互斥锁:int pthread_mutex_lock(pthread_mutex *mutex);
释放互斥锁:int pthread_mutex_unlock(pthread_mutex *mutex);
五消息队列
六.套接字
常见的socket分为以下三种
1.流式套接字SOCKET_STREAM:提供可靠的、面向连接的通信流。TCP就是采用流式套接字。
2.数据报套接字SOCKET_DGRAM:是一种不可靠、无连接的服务。UDP就是采用数据报套接字。
3.原始套接字:允许对底层协议直接访问,如IP或ICMP。主要用于协议的开发。