1> 使用文件IO完成,将源文件中的所有内容进行加密(大写转小写、小写转大写)后写入目标文件中
源文件内容不变
#include <myhead.h>
//定义大小写转换函数
void zhuanhuan(char *buf)
{
for(int i = 0; buf[i] != '\0'; i++)
{
if(buf[i] >= 'A' && buf[i] <= 'Z')
{
buf[i] = buf[i]+32;
}
else if(buf[i] >= 'a' && buf[i] <= 'z')
{
buf[i] = buf[i]-32;
}
}
}
int main(int argc, const char *argv[])
{
if(argc != 3)
{
printf("input error\n");
return -1;
}
int fd1 = -1; //读取
if((fd1 = open(argv[1], O_RDONLY)) == -1)
{
perror("fd1 open error");
return -1;
}
int fd2 = -1; //写入
if((fd2 = open(argv[2], O_WRONLY|O_CREAT|O_TRUNC, 0664)) == -1)
{
perror("fd2 open error");
return -1;
}
char buf[128] = "";
while(1)
{
int res = read(fd1, buf, sizeof(buf));
if(res == 0)
{
break;
}
zhuanhuan(buf);
write(fd2, buf, res);
}
close(fd1);
close(fd2);
printf("加密成功\n");
return 0;
}
2> 查资料了解以下概念:
并发和并行的区别
并发(Concurrency):
- 定义:并发是指系统能够处理多个任务或进程的能力,这些任务或进程可能在同一时间段内交替进行,但并不一定真正同时运行。并发更多的是一种任务的组织和管理方式。
- 特点:并发系统可以在有限的资源下处理多个任务,使得这些任务在时间上交错进行。它关注的是如何高效地管理和调度任务。
- 示例:一个操作系统可以在一个核心的处理器上同时处理多个进程,虽然这些进程不是同时运行的,但它们的执行是交替进行的。
并行(Parallelism):
- 定义:并行是指系统能够同时执行多个任务或进程。它要求硬件上有多个处理单元(如多个处理器核心)能够同时工作,从而实现真正的同时运行。
- 特点:并行计算是通过同时利用多个处理器或处理核心来提高计算效率。它关注的是如何在多个计算资源上同时执行任务。
- 示例:在一个具有多个核心的处理器上运行一个计算密集型的程序,不同的核心可以同时处理不同的计算任务
什么是进程
进程(Process)是操作系统中的一种重要概念,它指的是一个正在执行的程序的实体。更确切地说,一个进程是程序的一次执行实例,它拥有自己的地址空间、进程控制块(PCB)、属性(如优先级、进程ID等)、文件描述符、打开的文件、内存空间和其他系统资源。
进程是操作系统进行资源分配和调度的基本单位。每个进程都在操作系统控制下独立地运行,拥有自己的生命周期。进程可以通过fork、exec等系统调用或者通过编程语言提供的API来创建。
进程可以通过以下几种方式进行通信:
- 进程间通信(IPC):包括管道(pipe)、消息队列(message queue)、信号量(semaphore)、共享内存(shared memory)和套接字(socket)等。
- 文件:进程可以通过读写文件来进行通信。
- 网络:进程可以通过网络协议进行通信,比如使用TCP/IP。
进程可以根据其特点分为以下几种类型:
- 前台进程:直接与用户交互,并为用户提供服务的进程。
- 后台进程:不直接与用户交互,通常用于执行一些后台服务或者文件处理等任务。
- 守护进程(Daemon):在后台运行,没有控制终端的进程,通常用于提供某种系统服务。
进程的行为可以通过以下机制进行控制:
- 信号(Signal):用来向进程发送异步事件。
- 线程(Thread):一个进程中的多个线程可以并发执行。
- 互斥锁(Mutex)和信号量等机制可以用来同步进程间的操作。
- 死锁预防或检测:防止多个进程因为资源分配不当而陷入相互等待的状态。
进程的终止可以通过以下方式实现:
- 正常终止:进程完成其任务后正常退出。
- 异常终止:进程因为异常情况,如崩溃或者收到SIGKILL信号而终止。
进程和程序的区别
进程和程序是计算机科学中的两个基础概念,虽然它们密切相关,但有着本质的区别:
程序(Program):
- 定义:程序是一组按照特定语法编写的指令集合,通常以文件形式存在。程序本身不执行,只是存储在磁盘上的代码,是静态的。
- 特点:程序是静态的代码和数据的集合,不具有运行状态和执行环境。它描述了一个计算任务的逻辑步骤和操作。
- 示例:一个文本编辑器的源代码文件、一个编译好的二进制文件(如
.exe
文件)或脚本文件(如.py
或.sh
文件)。进程(Process):
- 定义:进程是程序在计算机上运行时的实例,是程序的执行过程。它是操作系统为程序执行分配资源后的动态表现。
- 特点:进程是动态的,具有自己的地址空间、内存、寄存器、堆栈等运行时资源。每个进程都具有独立的执行上下文,包括程序计数器、内存管理信息、进程控制块等。
- 示例:当你运行一个文本编辑器时,操作系统创建一个进程来执行该程序。这个进程包括程序代码、数据、程序计数器、文件描述符等。
总结:
- 程序是静态的,是存储在磁盘上的代码和数据,描述了如何完成特定任务的指令集。
- 进程是动态的,是程序在运行时的一个实例,包括程序代码及其执行所需的资源和状态信息。
简单来说,程序是一个未执行的代码集合,而进程是这个代码在执行时的实际表现和状态
进程的状态有哪些
创建状态:进程在创建时需要申请一个空白PCB,向其中填写控制和管理进程的信息,完成资源分配。如果创建工作无法完成,比如资源无法满足,就无法被调度运行,把此时进程所处状态称为创建状态
就绪状态:进程已经准备好,已分配到所需资源,只要分配到CPU就能够立即运行
执行状态:进程处于就绪状态被调度后,进程进入执行状态
阻塞状态:正在执行的进程由于某些事件(I/O请求,申请缓存区失败)而暂时无法运行,进程受到阻塞。在满足请求时进入就绪状态等待系统调用
终止状态:进程结束,或出现错误,或被系统终止,进入终止状态。无法再执
系统中的多个进程的调度机制都有哪些
- 先到先服务调度(FCFS)
- 短作业优先调度(SJF)
- 时间片轮转调度(Round Robin)
- 多级反馈队列调度(MLFQ)