绪论
Linux操作系统作为一个强大的开源操作系统,具有广泛的应用与发展。在Linux系统下,进程和作业的管理是其中一个重要的系统管理方面。实现进程和作业的高效管理是保证Linux系统运行稳定且高效的关键。本篇文章将介绍Linux系统下进程和作业的概念、分类、创建与终止、控制等方面的处理,并通过实验验证Linux系统下进程和作业的高效管理。
一、实验设计
本次实验共分为以下四部分:
1. 进程的创建与终止
2. 进程的状态转换
3. 进程的控制
4. 作业的控制
在实验的过程中,使用的主要工具为shell以及Linux系统自带的工具。在实验过程中,我们将会体验到Linux系统下进程和作业的管理,实现Linux系统下进程和作业的高效管理。
二、实验操作
1. 进程的创建与终止
进程的创建和终止是Linux系统下进程管理的常见操作。创建进程主要是通过fork()系统调用实现,而终止进程是通过exit()系统调用实现。
以下是实验代码
“`bash
#include
#include
#include
int mn(){
pid_t pid;
pid = fork();// 创建进程并返回子进程PID
if(pid > 0){
printf(“This is parent process,pid=%d,child pid=%d/n”,getpid(),pid);
}else if(pid == 0){
printf(“This is child process,pid=%d,parent pid=%d/n”,getpid(),getppid());
}else{
perror(“fork error”);// 如果创建进程失败,输出错误信息
}
exit(0);
}
“`
上述代码通过fork()函数创建一个子进程,对于父进程,它会返回子进程的PID,而对于子进程,它会返回0。
2. 进程的状态转换
在Linux系统下,进程的状态分为就绪态、运行态和阻塞态三种状态,进程的状态转换是Linux系统进程管理的重要部分。当操作系统调度一个进程时,就将其状态从就绪态转换为运行态,当进程等待输入/输出等操作时,就会进入阻塞态。
以下是实验代码:
“`bash
#include
#include
#include
int mn(){
pid_t pid;
pid=fork();
switch(pid){
case -1:
perror(“pid error”);
break;
case 0:
printf(“child process pid=%d status:running/n”,getpid());
sleep(5);//模拟子进程执行中
printf(“child process pid=%d status:exit/n”,getpid());
break;
default:
printf(“parent process pid=%d status:running/n”,getpid());
while(wtpid(pid,NULL,WNOHANG) == 0);//等待子进程结束
printf(“child process:%d exit/n”,pid);
printf(“parent process pid=%d status:exit/n”,getpid());
break;
}
return 0;
}
“`
其中,WNOHANG参数要求wtpid()函数在等待子进程结束时,不会阻塞等待。
3. 进程的控制
Linux系统下进程的控制主要是通过系统调用来实现。本篇文章中,我们使用Linux系统中自带的kill命令来对进程进行控制。kill命令可以发送信号到指定进程,使其做出相应的动作。例如,kill -9 PID命令可以终止指定进程。
以下是实验代码:
“`bash
#include
#include
#include
int mn(){
pid_t pid;
pid=fork();
if(pid == 0){
printf(“child process pid=%d running/n”,getpid());
sleep(5);//模拟子进程执行中
printf(“child process pid=%d exit/n”,getpid());
}
else if(pid > 0){
printf(“parent process pid=%d running/n”,getpid());
sleep(1);//主进程等待1秒,等待子进程运行
printf(“send signal to child process…/n”);
kill(pid,SIGKILL);//向子进程发送信号,终止其运行
}
else{
perror(“fork error”);
}
return 0;
}
“`
在上述代码中,我们通过kill()函数向指定进程发送信号。在本实验中,我们向子进程发送了SIGKILL信号,这将导致进程被终止。
4. 作业的控制
在Linux系统下,作业控制是进程管理的另一重要部分。在Linux系统下,每个作业都有一个作业号,通过作业号我们可以控制它的运行状态。作业控制主要是通过Linux系统中自带的job control命令实现。
以下是实验代码:
“`bash
#include
#include
#include
#include
#include
int mn(){
pid_t pid1,pid2;
pid1 = fork();
if(pid1 == 0){
printf(“child process1 pid=%d running…/n”,getpid());
sleep(10);
printf(“child process1 pid=%d exit/n”,getpid());
return 0;
}
pid2=fork();
if(pid2 == 0){
printf(“child process2 pid=%d running…/n”,getpid());
sleep(15);
printf(“child process2 pid=%d exit/n”,getpid());
return 0;
}
printf(“parent process pid=%d create child process1 pid=%d, child process2 pid=%d/n”,getpid(),pid1,pid2);
sleep(1);
printf(“parent process pid=%d:Ctrl-Z, Suspend/n”,getpid());
kill(pid1,SIGSTOP);//向进程pid1发送SIGSTOP信号,使其暂停
wtpid(pid1,NULL,WUNTRACED);//等待子进程1结束或者进入Suspended状态
printf(“parent process pid=%d:Ctrl-C, Terminate/n”,getpid());
kill(pid2,SIGINT);//向进程pid2发送SIGINT信号,使其终止
wtpid(pid2,NULL,0);//等待子进程2结束
return 0;
}
“`
在上述代码中,我们通过kill()函数向指定进程发送信号。在本实验中,我们向子进程1发送了SIGSTOP信号,使其进入Suspend状态,这将导致进程暂停运行,但是并没有被终止。在等待子进程1进入Suspended状态后,我们使用了wtpid()函数来等待其结束或进入Suspended状态。此外,我们还向子进程2发送了SIGINT信号,使其进程终止。
实验结果
根据实验设计,我们实现了进程的创建与终止、进程的状态转换、进程的控制、作业的控制等基本功能。通过实验,我们也深刻认识到Linux系统下进程和作业的管理思想和方法,实现了进程和作业在Linux系统下实现高效管理的目标。
结论
相关问题拓展阅读:
- Linux进程管理及作业控制的介绍
- 操作系统 linux
Linux进程管理及作业控制的介绍
Linux是一个多任务的操作系统拦芹,系简液毕统上同时运行着多个进程,正在执埋肆行的一个或多个相关进程称为一个作业。
操作系统 linux
别折腾了,退学吧~
华丽的匿了
平时还是要好好学习的,如果你在学校学得好的话,出来工作后会比别人发展快得多,如果不空毕好好学习,觉得学校学的东西没用的话。那你就大错特错了。
学得不好工作都不好找,学得好毕业就可以找一个很好的公司。起点不一样以后的发展大不一样。
至于你上面说的这些问兆灶题其实都是斗猜芹很基础的问题,现在很多公司招人面试问题比这个问题难多了。
对于试验1, 进程间通信可以用管道,消息队列,信号量,socket,共享内存等等。
对于试验2,创建进程用fork
对于试验3,消息队列主要用于交换少量数据,共享存储主要用于交换大块数据。
前两个写一个兄世简易的败尘咐文本编辑器就可以。所谓实时输入、显示就是文本编辑器的基本功能。在这个基础上,在写一个字符监测控制函数,利用这察纯个函数调用文件函数,不就全部解决掉了。
LINUX系统跟XP完全不一样,LINUX系统我用的少,不好意思,这个帮不上忙
关于linux的进程和作业控制实验报告的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
香港服务器首选树叶云,2H2G首月10元开通。
树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/160222.html<