Educoder--Linux实验--进程管理2(第1关~第4关)

题目描述、要求等就不过多赘诉

让我们直接上代码!!!!

第1关:进程等待

#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <stdio.h>
/************************
 * 返回值: 调用成功且子进程正常退出返回退出代码,否则返回-1
*************************/
int waitProcess()
{
	int status = -1;
	/********** BEGIN **********/
	 pid_t pid;
    pid = fork();
    if(pid == -1){
        //创建进程失败
        return -1;
    }
    else if(pid == 0){
        //子进程
        sleep(2);
        printf("This is child process\n");
        exit(1);
    }
    else{
        //父进程
        if(waitpid(-1, &status, 0) != -1){
            if(WIFEXITED(status))
                return WEXITSTATUS(status);
        }
        exit(0);
    }
	/********** END **********/
	return status;
}

第2关:进程创建操作-exec函数族

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
 
/************************
 * 提示: 在子进程中如果执行exec函数失败要使用exit函数正确退出子进程
*************************/
int execlProcess()
{
	pid_t pid = vfork();
	if(pid == -1){
		printf("创建子进程失败(%s)\n", strerror(errno));
		return -1;
	}
	else if(pid == 0){
		//子进程
		/********** BEGIN **********/
		if(execlp("touch", "touch", "testFile",  NULL) < 0){
            //执行execlp函数失败
            exit(-1);
        }
		
		/********** END **********/
	}
	else{
		//父进程
		/********** BEGIN **********/
		printf("Parent Process");
		/********** END **********/
	}
}

第3关:进程创建操作-system

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
 
/************************
 * 返回值: 调用成功返回命令的状态码,失败返回-1
*************************/
int createProcess()
{
	int ret = -1;
	/********** BEGIN **********/
	ret=system("mkdir testDir");
    if(ret == -1){
        return -1;
    }
	/********** END **********/
	return ret;
}

第4关:实现一个简单的命令解析器

#include <unistd.h>
#include <sys/types.h>
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <string.h>
#include <errno.h>

void RShell(char *cmd[], int commandNum)
{
    pid_t pid;
    //for (int i = 0; i < commandNum; i++) {
    int i = 0;
    while(commandNum) {
        pid = fork();
        if (pid == -1) {
            printf("创建进程失败(%s)!", strerror(errno));
            return -1;
        } else if (pid == 0) {
            char *file;
            char *point = NULL;
            char *tmpArg[10];
            point = strtok(cmd[i], " ");
            file = point;
            int index = 0;
            while (point != NULL) {
                if (index == 9)
                    break;
                tmpArg[index++] = point;
                point = strtok(NULL, " ");
            }
            char **arg = malloc(sizeof(char *) * (index + 1));
            int i;
            for (i = 0; i < index; i++)
                arg[i] = tmpArg[i];
            arg[index] = NULL;
            if (execvp(file, arg) < 0) {
                //执行execvp函数失败
                exit(-1);
            }
        } else {
            int status;
            wait(&status);
        }
        commandNum--;
        i++;
    }
}

### 回答1Linux进程管理有很多命令可以使用,其中常用的有以下几个: 1. ps: 显示当前系统中运行的进程。 2. top: 实时显示系统中所有进程的详细信息。 3. pkill: 杀死进程。 4. kill: 终止进程。 5. nice: 调整进程的优先级。 6. renice: 更改进程的优先级。 7. nohup: 使进程在你登出系统后仍然运行。 8. jobs: 显示当前系统中所有后台运行的进程。 9. fg: 将后台进程转移到前台。 10. bg: 将前台进程转移到后台。 ### 回答2: 进程是操作系统中的一个重要概念,Linux也不例外。Linux中的进程管理主要涉及进程创建、销毁、调度和通信等方面。在进程管理中,进程控制块(PCB)是一个重要的概念。 进程的创建通常由fork()系统调用实现,该系统调用会复制当前进程,产生一个子进程,然后子进程会继续执行接下来的代码逻辑。在创建进程时,Linux会为每个进程分配一个唯一的PID,并将进程的相信息保存在PCB中。进程退出时,会释放相资源,并在进程表中删除该进程的PCB等。 进程的调度由Linux内核完成,它决定了每个进程何时开始运行、何时停止以及它们的优先级。在进程调度过程中,内核会根据进程优先级来选择下一个要运行的进程。如果有多个可运行进程,则会按照分时调度算法,轮流选择每个进程运行。内核还提供了nice值用于控制进程的优先级。 进程通信是多个进程之间传输消息和共享资源的过程。在Linux中,有多种进程通信机制,如管道、套接字、信号量和共享内存等。每种通信机制都有自己的优缺点,适用于不同的场景。 总之,在Linux中进行进程管理是非常重要的,它能够确保系统的正常运行、提高系统的安全性和可靠性。对于Linux系统管理员来说,进程管理也是一项必不可少的技能。对于开发者来说,也需要深入理解Linux进程管理的相知识,以便更好地利用操作系统的功能来完成自己的开发工作。 ### 回答3: 进程管理Linux系统中最重要的一个功能,它可以帮助我们掌握计算机系统的运行情况,优化系统性能和保护系统安全。在Linux中,进程管理包括了进程的创建、删除、调度、信号传递等方面。本文将继续讲述进程管理的一些内容,主要包括进程间的通信、进程优先级、进程调度等方面。 一、进程间的通信 在Linux系统中,进程之间可以通过多种方式进行通信,例如管道、信号、共享内存、消息队列等。其中,管道是最简单的一种通信方式,它是一个单向的字节流,通信的两端分别是一个读端和一个写端。读端从管道中读取数据,写端向管道中写入数据。信号是用来通知进程发生了某个事件,接收信号的进程可以根据信号的类型做出相应的处理。共享内存是一种高效的通信方式,它允许多个进程访问同一块内存空间,从而避免了数据拷贝的开销。消息队列是一个消息传递的队列,发送进程将消息插入队列中,接收进程从队列中读取消息。 、进程优先级 在Linux中,进程的优先级决定了它们在调度器中的调度顺序。进程的优先级范围是-20到19,优先级越高,表示进程越重要。可以通过nice命令来改变进程的优先级,它接受一个优先级参数,优先级越高,对应的nice值越低。例如,将进程的优先级调整为最高可以这样做:nice -20 pid。SCHED_RR和SCHED_FIFO是两种实时调度策略,它们可以用来保证进程在预定的时间内得到调度,在调度时优先级高的进程先被调度。 三、进程调度 进程调度是系统的核心功能之一,它负责将CPU时间分配给多个进程。在Linux中,进程调度是由内核的调度器完成的,调度器会根据进程的优先级、调度策略、进程状态等因素来决定进程的调度顺序。除了内核自带的调度器外,Linux还允许用户自定义调度器,例如CFS和O(1)调度器等。CFS调度器是Linux内核中默认的调度器,它将CPU时间按照比例分配给各个进程,从而实现公平的调度;O(1)调度器则采用了更为简单的时间片轮转算法,保证了调度效率的同时也降低了系统负担。 总之,进程管理Linux系统中最为重要的一个功能,它包括了进程的创建、删除、调度、信号传递、进程间通信、进程优先级等方面。掌握这些知识可以帮助我们更好地管理系统资源,提高系统的性能和安全性。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值