笔记七:进程间的通信(IPC通信之信号灯)
|
功能
|
信号量(POSOX)
|
信号量灯(IPC)
|
|
定义信号变量
|
sem_t sem1
|
semget
|
|
初始化信号量
|
sem_init
|
semctl
|
|
P操作
|
sem_wait
|
semop
|
|
V操作
|
sem_post
|
semop
|
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <pthread.h>
#include <string.h>
#include <semaphore.h>
#define N 64
sem_t sem;
void * f(void *arg)
{
while (1)
{
sem_wait(&sem);
sleep(1);
printf("%s", (char *)arg);
}
}
int main()
{
pthread_t thread;
char buf[N]; //= "you are welcome";
void *thread_result;
if (sem_init(&sem, 0, 0) == -1)
{
perror("sem_init");
exit(-1);
}
if (pthread_create(&thread, NULL, f, buf) != 0)
{
fprintf(stderr, "pthread_create %s\n", strerror(errno));
exit(-1);
}
do
{
printf("input:");
fflush(stdout);
fgets(buf, N, stdin);
sem_post(&sem);//唤醒子线程 V操作
} while (strncmp(buf, "quit", 4));
return 0;
}信号灯集 (含有多个信号量)
|
所需头文件
|
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
|
|
函数原型
|
int semget(key_t key, int nsems, int semflg);
|
|
函数参数
|
key :和信号灯集关联的 key 值
|
|
|
nsems: 信号灯集中包含的信号灯数目
|
|
|
semflg :信号灯集的访问权限
|
|
函数返回值
|
成功:信号灯集 ID
|
|
|
出错: -1
|
|
所需头文件
|
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
|
|
函数原型
|
int semop ( int semid, struct sembuf *opsptr, size_t nops);
|
|
函数参数
|
semid :信号灯集 ID
struct sembuf {
short sem_num; // 要操作的信号灯的编号
short sem_op; // 0 : 等待,直到信号灯的值变成 0
// 1 : 释放资源, V 操作
// -1 : 分配资源, P 操作
short sem_flg; // 0, IPC_NOWAIT, SEM_UNDO
};
nops: 要操作的信号灯的个数
|
|
所需头文件
|
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
|
|
|
函数原型
|
int semctl ( int semid, int semnum, int cmd , … union semun arg(不是地址 ) );
|
|
|
函数参数
|
semid :信号灯集 ID
semnum: 要修改的信号灯编号
|
|
|
|
cmd :
|
GETVAL :获取信号灯的值
SETVAL :设置信号灯的值
IPC_RMID :从系统中删除信号灯集合
|
|
|
|
|
|
函数返回值
|
成功: 0
|
|
|
|
出错: -1
|
|
#include "stdio.h"
#include "sys/ipc.h"
#include "sys/sem.h"
#include "sys/types.h"
#include "stdlib.h"
/*联合体*/
union semun
{
int val; //SETVAL:设置信号灯的值
struct semid_ds *buf;
unsigned short *array;
struct seminfo *__buf;
};
int main()
{
int i;
int key;
int semid;
union semun mysemun;
struct sembuf mysembuf;
key=ftok("./a.c",'a');//touch a.c记得每次要先创建a.c
if(key < 0)
return -1;
semid=semget(key,2,IPC_CREAT | 0777);// 创建信号灯集
if(semid < 0)
return -2;
mysemun.val=0;//初始化信号灯
semctl(semid,0,SETVAL,mysemun);//初始化信号灯集,也可以删除信号灯;
/*先运行*/
for(i=0;i< 10 ;i++)
{
printf("this is first process\n");
sleep(1);
}
/*运行完以后进行唤醒 v操作*/
mysembuf.sem_num=0;
mysembuf.sem_op=1;//信号灯v操作
mysembuf.sem_flg=0;
semop(semid,&mysembuf,1);
return 0;
}#include "stdio.h"
#include "sys/ipc.h"
#include "sys/sem.h"
#include "sys/types.h"
#include "stdlib.h"
union semun
{
int val;
struct semid_ds *buf;
unsigned short *array;
struct seminfo *__buf;
};
int main()
{
int i;
int key;
int semid;
union semun mysemun;
struct sembuf mysembuf;
key=ftok("./a.c",'a');
if(key < 0)
return -1;
semid=semget(key,2,IPC_CREAT | 0777);
if(semid < 0)
return -2;
/*后运行不需要在初始化*/
//mysemun.val=0;
//semctl(semid,0,SETVAL,mysemun);
//
mysembuf.sem_num=0;
mysembuf.sem_op=-1;//信号灯p操作
mysembuf.sem_flg=0;
semop(semid,&mysembuf,1);
for(i=0;i< 10 ;i++)
{
printf("this is second process\n");
sleep(1);
}
return 0;
}
笔记七:进程间的通信(IPC通信之信号灯)的更多相关文章
- 进程间的通讯(IPC)方式
内存映射 为什么要进行进程间的通讯(IPC (Inter-process communication)) 数据传输:一个进程需要将它的数据发送给另一个进程,发送的数据量在一个字节到几M字节之间共享数据 ...
- Android进阶笔记04:Android进程间通讯(IPC)之Messenger
一. Android进程间通讯之Messenger 的引入 (1)引言: 平时一说进程间通讯,大家都会想到AIDL,其实messenger和AIDL作用一样,都可以进行进程间通讯.它是基于消 ...
- Android(java)学习笔记232:Android进程间通讯(IPC)之AIDL
一.IPC inter process communication 进程间通讯 二.AIDL android interface defination language 安卓接口定义语言 满 ...
- Android(java)学习笔记175:Android进程间通讯(IPC)之AIDL
一.IPC inter process communication 进程间通讯 二.AIDL android interface defination language 安卓接口定义语言 满 ...
- Windows进程间通讯(IPC)----WM_COPYDATA
WM_COPYDATA通讯思路 通过向其他进程的窗口过程发送WM_COPYDATA消息可以实现进程间通讯. 只能通过SendMessage发送WM_COPYDATA消息,而不能通过PostMessag ...
- Windows进程间通讯(IPC)----内存映射文件
内存映射文件原理 内存映射文件是通过在虚拟地址空间中预留一块区域,然后通过从磁盘中已存在的文件为其调度物理存储器,访问此虚拟内存空间就相当于访问此磁盘文件了. 内存映射文件实现过程 HANDLE hF ...
- Windows进程间通讯(IPC)----管道
管道的分类 管道其实际就是一段共享内存,只不过Windows规定需要使用I/O的形式类访问这块共享内存,管道可以分为匿名管道和命名管道. 匿名管道就是没有名字的管道,其支持单向传输数据,如果需要双向传 ...
- 进程间的通讯————IPC
""" IPC 指的是进程间通讯 之所以开启子进程 肯定需要它帮我们完成任务 很多情况下 需要将数据返回给父进程 然而 进程内存是物理隔离的 解决方案: 1.将共享数据放 ...
- UNIX 进程间通讯(IPC)概念(Posix,System V IPC)
IPC(Inter-Process Communication,进程间通讯)可以有三种信息共享方式(随文件系统,随内核,随共享内存).(当然这里虽然说是进程间通讯,其实也是可以和线程相通的). 相对 ...
- Windows进程间通讯(IPC)----消息队列
消息队列 windows系统是通过消息驱动的,每移动一下鼠标,点击一下屏幕都会产生一个消息.这些消息会先被放在windows的一个系统消息队列(先进先出)中,windows系统会为每一个GUI线程创建 ...
随机推荐
- html:表格
HTML:表格1.表格三标签:(1)<table> 表格(2)<tr> 行(3)<td> 单元格 2.表格的基本语法和结构<table> <t ...
- <a-upLoad>连报三错
[Vue warn]: Invalid prop: custom validator check failed for prop "fileList". [Vue warn]: I ...
- sqlserver 生成随机值
随机生成100以内的整数 select top 10 number,ceiling(rand(checksum(newid()))*100) from master.dbo.spt_valueswhe ...
- el与data的两种写法
el的两种写法 Vue初始化(被创建)后会判断有无el 有el:创建Vue实例对象的时候配置el属性 无el:通过vm.$mount('#root')指定el的值 data的两种写法 对象式:data ...
- 我用 Laf 三分钟写了一个专属 ChatGPT ,Laf 创始人:明天来上班!
起因 故事是这样的,一个月黑风高的夜晚,我掏出手机像往常一样打开朋友圈. 一开始我是不相信的,直到我(快速的) --> 打开 laf --> 创建应用 --> 新建云函数 --> ...
- 使用python-gitlab获取本地gitlab仓库project信息的方法
代码中有注释,直接看代码 #coding:utf8 #!/usr/bin/env python #@author: 9527 import gitlab import openpyxl import ...
- 每次SSH执行完都会关闭通道,返回目录,如果想一次执行多步操作,需要多条命令才能达到目的时,用;分割操作指令,一并导入执行
每次SSH执行完都会关闭通道,返回目录,如果想一次执行多步操作,需要多条命令才能达到目的时,用:分割操作指令,一并导入执行: 例如: self.execmd='cd ../tmp/log/;pwd;t ...
- SpringBoot——入门及原理
SpringBoot 用来简化 Spring应用开发,约定大于配置,去繁从简,是由 Pivotal团队提供的全新框架.其设计目的是用来简化新 Spring应用的初始搭建以及开发过程.该框架使用了特定的 ...
- JAVA异步编程之Callbacks与Futures模型
JAVA异步编程之Callbacks与Futures模型 一:Callbacks模型 该模型的异步方法,在异步任务完成之后调用,主线程没有异步线程的结果.经典模型如Swing's EventLis ...
- ArcGIS模型构建器ModelBuilder的使用方法
本文介绍在ArcMap软件中,基于模型构建器(ModelBuilder)完成模型建立与使用的具体方法. 首先,在ArcMap软件中打开"ModelBuilder". 建 ...