【嵌入式学习】IO进程线程day02.22

一、思维导图

二、习题

1> 将互斥机制的代码实现

#include <myhead.h>

//定义一个全局变量
char str[128]="我是一个全局字符串数组";
//1、创建一个互斥锁变量
pthread_mutex_t mutex;

//线程1
void *pth1(void *arg)
{
	//上锁
	pthread_mutex_lock(&mutex);
	//对全局变量进行操作
	strcat(str,",我现在在线程1");
	//输出
	printf("我是线程1输出:%s\n",str);
	//解锁
	pthread_mutex_unlock(&mutex);
}

//线程2
void *pth2(void *arg)
{
	//上锁
	pthread_mutex_lock(&mutex);
	//对全局变量进行操作
	strcpy(str,",我现在在线程2");

	printf("我是线程2输出:%s\n",str);

	//解锁
	pthread_mutex_unlock(&mutex);
}

int main(int argc, const char *argv[])
{
	//2、初始化所资源
	pthread_mutex_init(&mutex,NULL);
	//定义线程号
	pthread_t tid1=-1;
	pthread_t tid2=-1;

	//创建分支线程1 
	if(pthread_create(&tid1,NULL,pth1,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	//创建分支线程2
	if(pthread_create(&tid2,NULL,pth2,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}


	pthread_join(tid1,NULL);
	pthread_join(tid2,NULL);
	printf("程序结束\n");
	//销毁互斥锁
	pthread_mutex_destroy(&mutex);
	return 0;
}

 

2> 将无名信号量的代码实现

#include <myhead.h>

//定义无名信号量
sem_t sem;

//线程1
void *pth1(void *arg)
{
	int n=5;
	while(n--)
	{
	sleep(1);
	//输出
	printf("我是特斯拉顶级销售,谁要买车!!!\n");

	sem_post(&sem);
	}
	pthread_exit(NULL);
}

//线程2
void *pth2(void *arg)
{
	int n=5;
	while(n--)
	{
	sem_wait(&sem);
	printf("我要买车\n");
	}
	pthread_exit(NULL);
}

int main(int argc, const char *argv[])
{
	//初始化无名信号量
	sem_init(&sem,0,0);
	//定义线程号
	pthread_t tid1=-1;
	pthread_t tid2=-1;
	//创建分支线程1 
	if(pthread_create(&tid1,NULL,pth1,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	//创建分支线程2
	if(pthread_create(&tid2,NULL,pth2,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	



	pthread_join(tid1,NULL);
	pthread_join(tid2,NULL);

	printf("程序结束\n");
	//销毁无名信号量
	sem_destroy(&sem);
	return 0;
}
ubuntu@ubu

 

3> 将条件变量的代码实现

#include <myhead.h>

//1、定义
pthread_cond_t cond;

//1、定义互斥锁
pthread_mutex_t mutex;

//线程1
void *pth1(void *arg)
{
	
	int num=5;
	while(num--)
	{
		sleep(1);

		printf("%#lx:我是特斯拉顶级销售\n",pthread_self());

		//3、唤醒一个消费者
		pthread_cond_signal(&cond);
	}
	pthread_exit(NULL);
}

//线程2
void *pth2(void *arg)
{
	//3、上锁
	pthread_mutex_lock(&mutex);
	//4、等待条件变量
	pthread_cond_wait(&cond,&mutex);
	printf("我是%#lx:我要来买车\n",pthread_self());
	//4、解锁
	pthread_mutex_unlock(&mutex);

	pthread_exit(NULL);
}

int main(int argc, const char *argv[])
{
	//2、初始化条件变量
	pthread_cond_init(&cond,NULL);
	//2、初始化互斥锁
	pthread_mutex_init(&mutex,NULL);
	//定义线程号
	pthread_t tid1,tid2,tid3,tid4,tid5,tid6;
	//创建分支线程1 
	if(pthread_create(&tid1,NULL,pth1,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	//创建分支线程2
	if(pthread_create(&tid2,NULL,pth2,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	//创建分支线程3
	if(pthread_create(&tid3,NULL,pth2,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	//创建分支线程4
	if(pthread_create(&tid4,NULL,pth2,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	//创建分支线程5
	if(pthread_create(&tid5,NULL,pth2,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	//创建分支线程6
	if(pthread_create(&tid6,NULL,pth2,NULL)!=0)
	{
		printf("ERROR");
		return -1;
	}
	pthread_join(tid1,NULL);
	pthread_join(tid2,NULL);
	pthread_join(tid3,NULL);
	pthread_join(tid4,NULL);
	pthread_join(tid5,NULL);
	pthread_join(tid6,NULL);
	printf("程序结束\n");
	//释放互斥锁
	pthread_mutex_destroy(&mutex);
	//释放条件变量
	pthread_cond_destroy(&cond);
	return 0;
}

 

4> 将无名管道的代码实现

#include <myhead.h>
int main(int argc, const char *argv[])
{
	//创建管道文件
	int pipefd[2]={0};
	if(pipe(pipefd)==-1)
	{
		perror("pipe error");
		return -1;
	}
	printf("pipefd[0]=%d,pipefd[1]=%d\n",pipefd[0],pipefd[1]);

	//创建子进程
	pid_t pid=fork();
	if(pid>0)
	{
		close(pipefd[0]);
		char wbuf[128]="";
		while(1)
		{
			bzero(wbuf,sizeof(wbuf));

			fgets(wbuf,sizeof(wbuf),stdin);
			wbuf[strlen(wbuf)-1]=0;
			write(pipefd[1],wbuf,strlen(wbuf));
			if(strcmp(wbuf,"quit")==0)
			{
				break;
			}
		}
		close(pipefd[1]);
		wait(NULL);
	}
	else if(pid==0)
	{
		close(pipefd[1]);

		char rbuf[128]="";
		while(1)
		{
			bzero(rbuf,sizeof(rbuf));

			read(pipefd[0],rbuf,sizeof(rbuf));

			printf("传来的数据:%s\n",rbuf);
			if(strcmp(rbuf,"quit")==0)
			{
				break;
			}

			close(pipefd[0]);

			exit(EXIT_SUCCESS);
		}
	}
		else
		{
			perror("error");
			return -1;
		}
	return 0;
}

 

5> 将有名管道的代码实现

#include <myhead.h>
int main(int argc, const char *argv[])
{
	if((mkfifo("./MYFIFO",0664))==-1)
	{
		perror("error");
		return -1;
	}
	//阻塞
	getchar();
	system("rm MYFIFO");
	return 0; 
}
#include <myhead.h>
int main(int argc, const char *argv[])
{
	int wfd=-1;
	if((wfd=open("./MYFIFO",O_WRONLY))==-1)
	{
		perror("error");
		return -1;
	}
	
	char str[128]="";
	while(1)
	{
		fgets(str,sizeof(str),stdin);

		str[strlen(str)-1]=0;
		write(wfd,str,strlen(str));
		if(strcmp(str,"quit")==0)
		{
			break;
		}
	}
	close(wfd);
	return 0;
}
#include <myhead.h>
int main(int argc, const char *argv[])
{
	int rfd=-1;
	if((rfd=open("./MYFIFO",O_RDONLY))==-1)
	{
		perror("error");
		return -1;
	}

	char str[128]="";
	while(1)
	{
		bzero(str,sizeof(str));
		read(rfd,str,sizeof(str));
		printf("接受的数据:%s\n",str);
		if(strcmp(str,"quit")==0)
		{
			break;
		}
	}
	close(rfd);
	return 0;
}

6> 使用有名管道完成两个进程的相互通信(提示:可以使用多进程或多线程完成)

#include <myhead.h>

//线程1:实现写功能
void *task1(void *arg)
{
	int wfd=-1;
	if((wfd=open("./MYFIFO2",O_WRONLY))==-1)
	{
		perror("error");
	}
	
	char str[128]="";
	while(1)
	{
		fgets(str,sizeof(str),stdin);
		str[strlen(str)-1]=0;
		write(wfd,str,strlen(str));
		if(strcmp(str,"quit")==0)
		{
			break;
		}
	}
	close(wfd);

	pthread_exit(NULL);
}

//线程2:实现读功能
void *task2(void *arg)
{
	int rfd=-1;
	if((rfd=open("./MYFIFO1",O_RDONLY))==-1)
	{
		perror("error");
	}

	char str[128]="";
	while(1)
	{
		bzero(str,sizeof(str));
		read(rfd,str,sizeof(str));
		printf("从康康接受的数据:%s\n",str); 
		if(strcmp(str,"quit")==0)
		{
			break;
		}
	}
	close(rfd);
	pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
	//创建分线程
	pthread_t pid1=-1;
	pthread_t pid2=-1;

	//设置无名

	if(pthread_create(&pid1,NULL,task1,0)!=0)
	{
		printf("ERROR");
		return -1;
	}
	if(pthread_create(&pid2,NULL,task2,0)!=0)
	{
		printf("ERROR");
		return -1;
	}
	pthread_join(pid1,NULL);
	pthread_join(pid2,NULL);
	
	return 0;
}
#include <myhead.h>

//线程1:实现写功能
void *task1(void *arg)
{
	int wfd=-1;
	if((wfd=open("./MYFIFO1",O_WRONLY))==-1)
	{
		perror("error");
	}
	
	char str[128]="";
	while(1)
	{
		fgets(str,sizeof(str),stdin);
		str[strlen(str)-1]=0;
		write(wfd,str,strlen(str));
		if(strcmp(str,"quit")==0)
		{
			break;
		}
	}
	close(wfd);
	pthread_exit(NULL);

}

//线程2:实现读功能
void *task2(void *arg)
{
	int rfd=-1;
	if((rfd=open("./MYFIFO2",O_RDONLY))==-1)
	{
		perror("error");
	}

	char str[128]="";
	while(1)
	{
		bzero(str,sizeof(str));
		read(rfd,str,sizeof(str));
		printf("从小康接受的数据:%s\n",str); 
		if(strcmp(str,"quit")==0)
		{
			break;
		}
	}
	close(rfd);
	pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
	//创建分线程
	pthread_t pid1=-1;
	pthread_t pid2=-1;

	if(pthread_create(&pid1,NULL,task1,0)!=0)
	{
		printf("ERROR");
		return -1;
	}
	if(pthread_create(&pid2,NULL,task2,0)!=0)
	{
		printf("ERROR");
		return -1;
	}
	pthread_join(pid1,NULL);
	pthread_join(pid2,NULL);
	return 0;
}
#include <myhead.h>
int main(int argc, const char *argv[])
{
	if((mkfifo("./MYFIFO1",0664))==-1)
	{
		perror("error");
		return -1;
	}
	//阻塞
	getchar();
	system("rm MYFIFO1");
	return 0; 
}
#include <myhead.h>
int main(int argc, const char *argv[])
{
	if((mkfifo("./MYFIFO2",0664))==-1)
	{
		perror("error");
		return -1;
	}
	//阻塞
	getchar();
	system("rm MYFIFO2");
	return 0; 
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/402547.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Azuki NFT 概览与数据分析

作者&#xff1a;stellafootprint.network 编译&#xff1a;cicifootprint.network 数据源&#xff1a;Azuki NFT Collection Dashboard Azuki NFT 将动漫艺术与实用性相结合&#xff0c;培育了一个充满活力的 Web3 社区。 这个 NFT 项目会在 2024 年崛起吗&#xff1f; …

keepalived双活互备模式测试

文章目录 环境准备部署安装keepavlived配置启动测试模拟Nginx宕机重新启动问题分析 环境准备 测试一下keepalived的双主模式&#xff0c;所谓双主模式就是两个keepavlied节点各持有一个/组虚IP&#xff0c;默认情况下&#xff0c;二者互为主备&#xff0c;同时对外提供服务&am…

运维07:堡垒机

什么是跳板机 跳板机就是一台服务器而已&#xff0c;运维人员在使用管理服务器的时候&#xff0c;必须先连接上跳板机&#xff0c;然后才能去操控内网中的服务器&#xff0c;才能登录到目标设备上进行维护和操作 开发小张 ---> 登录跳板机 ---> 再登录开发服务器 测试…

[AI]部署安装有道QanyThing

前提条件&#xff1a; 1、win10系统更新到最新的版本&#xff0c;系统版本最好为专业版本 winver 查看系统版本&#xff0c;内部版本要大于19045 2、CPU开启虚拟化 3、开启虚拟化功能&#xff0c;1、2、3每步完成后均需要重启电脑&#xff1b; 注&#xff1a;windows 虚拟…

C++模板->模板的概念、函数模板基本语法、函数模板注意事项、普通函数与函数模板区别、普通函数与函数模板调用规则、模板的局限性

#include<iostream> using namespace std; //交换两个整型函数 void swapInt(int& a, int& b) { int temp a; a b; b temp; } //交换两个浮点型函数 void swapDouble(double& a, double& b) { double temp a; a b; b te…

Unity Meta XR SDK 快捷配置开发工具【Building Block/Quick Action/OVRCameraRigInteraction】

文章目录 &#x1f4d5;教程说明&#x1f4d5;Building Block&#x1f4d5;Quick Action&#x1f4d5;OVRCameraRigInteraction 此教程相关的详细教案&#xff0c;文档&#xff0c;思维导图和工程文件会放入 Spatial XR 社区。这是一个高质量 XR 社区&#xff0c;博主目前在内…

计算机网络Day02--物理层(一)

计算机网络Day02–物理层 物理层基本概念 物理层考虑的是怎么才能在连接各种计算机的传输媒体上传输比特流&#xff0c;而不是具体的传输媒体 作用&#xff1a;尽可能屏蔽掉不同传输媒体和通信手段的差异 用于物流层的协议也称为物流层规程 主要作用&#xff1a;解决计算机…

基于SpringBoot + Layui的社区物业管理系统

项目介绍 社区物业管理系统是基于java编程语言&#xff0c;springboot框架&#xff0c;idea工具&#xff0c;mysql数据库进行开发&#xff0c;本系统分为业主和管理员两个角色&#xff0c;业主可以登陆系统&#xff0c;查看车位费用信息&#xff0c;查看物业费用信息&#xff0…

yml配置文件中常见的配置及含义

1.数据库连接的相关配置 项目名称:datasource:driver-class-name: com.mysql.cj.jdbc.Driverhost: localhostport: 3306database: 数据库名username: 用户名password: 密码 springboot配置文件,用于配置数据库源连接信息 数据库驱动类型为com.mysql.cj.jdbc.Driver,这是数据…

linux逻辑卷/dev/mapper/centos-root扩容增加空间

centos7中/dev/mapper/centos-root扩容 问题文件系统根目录&#xff0c;/dev/mapper/centos-root空间满了&#xff0c;导致k8s不停重启 1.查看磁盘情况 df -h #查看最大占用目录 du -h -x --max-depth12.查看磁盘信息 fdisk -l3.查看磁盘分区层级 lsblk4.新建分区 在/dev…

面试答疑03

1、登录鉴权怎么做的&#xff1f;为什么采用jwt的方式&#xff1f;有什么好处&#xff1f; Java登录鉴权常见的实现方式包括**CookieSession、HTTP Basic Authentication、ServletJDBC**等。 在Java的Web应用中&#xff0c;登录鉴权是确认用户身份的关键环节。一个常用的传统…

补环境框架过某物

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;不提供完整代码&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01;wx a15018…

2024年最火副业揭示:抖音小店无货源,我每小时收入高达2000

大家好&#xff0c;我是电商花花。 昨天刷到一条网友的帖子&#xff0c;“没有副业根本活不下去”&#xff0c;说的心里一紧。 细细品味&#xff0c;说的还真的挺对&#xff0c;大多数人都只是只有一个收入渠道&#xff0c;那就是上班&#xff0c;上班才会有收入&#xff0c;…

Typescript初体验

Typescript Typescript 官网地址: https://www.typescriptlang.org/zh/ 使用 nvm 来管理 node 版本: https://github.com/nvm-sh/nvm 装 Typescript: npm install -g typescript使用 tsc 全局命令&#xff1a; // 查看 tsc 版本 tsc -v // 编译 ts 文件 tsc fileName.ts1.…

外包干了三年,技术算是废了。。。

先说一下自己的个人情况&#xff0c;大专生&#xff0c;17年通过校招进入湖南某软件公司&#xff0c;干了接近5年的手工测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了五年的手工…

力扣基础刷题---二分查找

704. 二分查找 给定一个 n 个元素有序的&#xff08;升序&#xff09;整型数组 nums 和一个目标值 target &#xff0c;写一个函数搜索 nums 中的 target&#xff0c;如果目标值存在返回下标&#xff0c;否则返回 -1。 中心思想&#xff1a;找到中间值&#xff0c;跟中间值比…

PCIE1—快速实现PCIE接口上下位机通信(一)

1.简介 PCI Express&#xff08;PCIE&#xff09;是一种高速串行总线标准&#xff0c;广泛应用于计算机系统中&#xff0c;用于连接主板和外部设备。在FPGA领域中&#xff0c;PCIE也被广泛应用于实现高速数据传输和通信。FPGA是一种灵活可编程的集成电路&#xff0c;可以根据需…

时序数据库TimescaleDB,实战部署全攻略

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

bat 查找文件所在

脚本 在批处理文件&#xff08;.bat&#xff09;中查找文件所在的目录&#xff0c;你可以使用dir命令结合循环和条件语句来实现。以下是一个简单的示例&#xff0c;演示如何在批处理文件中查找指定文件并输出其所在目录&#xff1a; echo off setlocal enabledelayedexpansio…

绩效域-错题笔记

1、虚荣指标&#xff1a;对决策没有帮助的度量指标一般属于虚荣指标。 例如&#xff1a;新访问者的数量比网站的页面访问量更加有用。 2、完工偏差(VAC)用于预测预算赤字或盈余金额&#xff0c;它表示为完工预算(BAC)和完工估算(EAC)之差。 3、完工尚需绩效指数(TCPI)用于估…