IO进程线程8月27日

2024-08-28 04:36
文章标签 线程 进程 io 27

本文主要是介绍IO进程线程8月27日,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1,思维导图

2,使用两个线程分别复制文件的上下两部分到同一个文件

#include<myhead.h>
sem_t fastsem;
//pthread_mutex_t fastmutex;
void *capy_up(void *c)
{
//	pthread_mutex_lock(&fastmutex);int len=*(int *)c;int fp1=open("./1.txt",O_RDONLY);int fp2=open("./2.txt",O_WRONLY);char str[5];int read_cs;int count=0;while(count<len/2&&(read_cs=read(fp1,str,sizeof(str)))>0){count+=read_cs;if(count>len/2){write(fp2,str,(read_cs-(count-len/2)));break;}write(fp2,str,read_cs);}close(fp1);close(fp2);sem_post(&fastsem);
//	pthread_mutex_unlock(&fastmutex);pthread_exit(NULL);
}
void *capy_dn(void *c)
{
//	pthread_mutex_lock(&fastmutex);sem_wait(&fastsem);int len=*(int *)c;int fp3=open("./1.txt",O_RDONLY);int fp4=open("./2.txt",O_WRONLY|O_APPEND);lseek(fp3,len/2,SEEK_SET);char str[5];int read_cs;int count=0;while((read_cs=read(fp3,str,sizeof(str)))>0){write(fp4,str,read_cs);}close(fp3);close(fp4);
//	pthread_mutex_unlock(&fastmutex);sem_post(&fastsem);pthread_exit(NULL);
}int main(int argc, const char *argv[])
{
//	pthread_mutex_init(&fastmutex,NULL);sem_init(&fastsem,0,0);int fp1=open("./1.txt",O_RDONLY);int fp2=open("./2.txt",O_WRONLY|O_CREAT|O_TRUNC,0664);int len=lseek(fp1,0,SEEK_END);close(fp1);close(fp2);pthread_t tid1;int k1=pthread_create(&tid1,NULL,capy_up,&len);pthread_t tid2;int k2=pthread_create(&tid2,NULL,capy_dn,&len);if(k1!=0||k2!=0){perror("ptcreat");return -1;}
//	pthread_mutex_destroy(&fastmutex);sem_destroy(&fastsem);pthread_join(tid1,NULL);pthread_join(tid2,NULL);return 0;
}

3,使用四个线程通过无名信号量实现 “春“ ”夏“ ”秋“ ”冬“ 循环

#include<myhead.h>
sem_t sem1,sem2,sem3,sem4;
void *fun1(void *c)
{while(1){sem_wait(&sem4);sleep(1);printf("春\t");fflush(stdout);sem_post(&sem3);}pthread_exit(NULL);
}
void *fun2(void *x)
{while(1){sem_wait(&sem3);sleep(1);printf("夏\t");fflush(stdout);sem_post(&sem2);}pthread_exit(NULL);
}
void *fun3(void *q)
{while(1){sem_wait(&sem2);sleep(1);printf("秋\t");fflush(stdout);sem_post(&sem1);}pthread_exit(NULL);
}
void *fun4(void *d)
{while(1){sem_wait(&sem1);sleep(1);printf("冬\t");fflush(stdout);sem_post(&sem4);}pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{sem_init(&sem1,0,0);sem_init(&sem2,0,0);sem_init(&sem3,0,0);sem_init(&sem4,0,1);pthread_t tid1,tid2,tid3,tid4;if(pthread_create(&tid1,NULL,fun1,NULL)!=0){perror("ptcreat1");return -1;}if(pthread_create(&tid2,NULL,fun2,NULL)!=0){perror("ptcreat1");return -1;}if(pthread_create(&tid3,NULL,fun3,NULL)!=0){perror("ptcreat1");return -1;}if(pthread_create(&tid4,NULL,fun4,NULL)!=0){perror("ptcreat1");return -1;}sem_destroy(&sem1);sem_destroy(&sem2);sem_destroy(&sem3);sem_destroy(&sem4);pthread_join(tid1,NULL);pthread_join(tid2,NULL);pthread_join(tid3,NULL);pthread_join(tid4,NULL);return 0;
}

这篇关于IO进程线程8月27日的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113746

相关文章

SpringBoot实现虚拟线程的方案

《SpringBoot实现虚拟线程的方案》Java19引入虚拟线程,本文就来介绍一下SpringBoot实现虚拟线程的方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录什么是虚拟线程虚拟线程和普通线程的区别SpringBoot使用虚拟线程配置@Async性能对比H

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

WinForm跨线程访问UI及UI卡死的解决方案

《WinForm跨线程访问UI及UI卡死的解决方案》在WinForm开发过程中,跨线程访问UI控件和界面卡死是常见的技术难题,由于Windows窗体应用程序的UI控件默认只能在主线程(UI线程)上操作... 目录前言正文案例1:直接线程操作(无UI访问)案例2:BeginInvoke访问UI(错误用法)案例

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab