笔记七:进程间的通信(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线程创建 ...
随机推荐
- Rfost的自我介绍+软工五问
自我介绍+软工五问 问题 解答 这个作业属于哪个课程 网工1934-软件工程 这个作业要求在哪里 作业要求 这个作业的目标 让学生对软件工程有个初步的了解,同时掌握基础的markdown语法和博客园的 ...
- SQL的分类
DDL: 数据定义语言,用来定义数据库对象(数据表,表 ,字段) : DML:数据操作语言,用来对数据库表中的数据进行增删改 : DQL:数据库查询语言,用来查询数据库中的表的记录 DCL:数据控制语 ...
- C/C++ 数据结构单链表的实现(初始化、插入、删除、销毁)
#include <iostream> #include <Windows.h> #define MAX_SIZE 100 using namespace std; //单链表 ...
- c# Visual Studio|There is no editor available for ***,make sure the application for the file type(.vb) is installed问题解决方法
这个问题出现在在使用VS编码当中,电脑意外关机,导致的文件的缺失或者损坏. 使用反编译软件(如:ILSpy)对编译后的 .EXE文件进行反编译,在翻遍的结果中将相关代码拷贝至目标路径下,替换所需文件. ...
- js延迟加载、js异步加载
1.js延迟加载 (1)js延迟加载是js性能优化的一种方式 (2)作用:为了提高网页的加载速度 (3)原理:等网页加载完成之后再加载js文件 ··需要优化的原因:HTML元素是按照其在页面中出现的次 ...
- windows server 2008 创建计划任务不能正常执行
- Arduino优化 减少重复代码 例2
Example->Blink: void setup() { pinMode(LED_BUILTIN, OUTPUT); } void loop() { digitalWrite(LED_BUI ...
- Spring全家桶
常用框架的知识点汇总,如图: 一.5个常用的spring框架 ▌1.spring framework 也就是我们经常说的spring框架,包括了ioc依赖注入,Context上下文.bean管理.sp ...
- TypeScript 学习笔记 — infer 类型推导、类型兼容 (九)
目录 1.ReturnType 返回值类型 2.Parameters 参数类型 3.InstanceType 实例类型 4.ConstructorParameters 构造函数参数类型 5.infer ...
- Android 音视频采集那些事
音视频采集 在整个音视频处理的过程中,位于发送端的音视频采集工作无疑是整个音视频链路的开始.在 Android 或者 IOS 上都有相关的硬件设备--Camera 和麦克风作为输入源.本章我们来分析如 ...