【0802作业】打印时钟在终端上,若终端输入quit,结束时钟)

作业1:守护进程

守护进程的创建(5步):

  1. 创建孤儿进程:所有工作都在子进程中执行,从形式上脱离终端控制。
    fork(), 退出父进程
  2. 创建新的会话组:使子进程完全独立出来,防止兄弟进程对其有影响。
    setsid() 函数
    功能:创建一个新的进程组和会话组,成为该进程组和会话组组长;
    原型:
           #include <sys/types.h>
           #include <unistd.h>
    
           pid_t setsid(void);
  3. 修改当前孤儿进程的运行目录为不可卸载的文件系统:例如根目录,/tmp;防止运行目录被删除后,导致进程崩溃
    chdir函数
    功能:修改运行目录;
           #include <unistd.h>
    
           int chdir(const char *path);
    chdir("/");
    
    注意:从当前位置往后,运行在指定的目录下;
  4. 重设文件权限掩码:umask(0), 一般清零;
  5. 关闭所有文件描述符,从父进程继承过来的文件描述符不会用到,浪费资源。

代码:

 #include <stdio.h>
 #include <stdlib.h>
 #include <sys/types.h>
 #include <sys/wait.h>
 #include <sys/stat.h>
 #include <unistd.h>
 int main(int argc, const char *argv[])
 {
     //创建孤儿进程
     pid_t cpid = fork();
     if(0 == cpid)
     {
         //创建新的回话
         pid_t sid =setsid();
         printf("sid = %d\n",sid);
         //修改运行目录为不可卸载的文件目录下
         chdir("/");
         //清空文件权限掩码
         umask(0);
         //关闭所有文件描述符
         for(int i = 0;i<getdtablesize();i++)
             close(i);
 
         while(1)
         {
             //守护进程运行的周期性代码
             sleep(1);
         }
     }
     return 0;
 }

  • 输入ps ajx可查看进程之间的关系;
  • 输入pidof 文件名 可查看该文件是否有进程在运行;
  • 可通过 【kill -9 进程的pid号】将这个进程杀死;
  • 也可通过【killall -9 文件名】将该文件的所有在运行的进程杀死。

作业2:打印时钟在终端上,若终端输入quit,结束时钟

#include <stdio.h>
#include <head.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <time.h>
int main(int argc, const char *argv[])
{
    time_t t=0;
    struct tm* info=NULL;
    char input[10]="";
    int wtatus=0;
    int o=0;
    pid_t cpid=fork();
    if(cpid == 0)
    {
        while(1)
        {
            t = time(NULL);
            info = localtime(&t);
            printf("%d-%02d-%0d %02d:%02d:%02d\r",info->tm_year+1900, info->tm_mon+1, info->tm_mday,info->tm_hour, info->tm_min, info->tm_sec);
            fflush(stdout);
            sleep(1);
        }
        _exit(0);
    }
    if(cpid >0)
    {
        while(1)
        {                                                                                                                                                 
            bzero(input,sizeof(input));
            fgets(input,sizeof(input),stdin);
            puts(input);
            o=strcmp(input,"quit\n");
            if(0 == o)
            {
                kill(cpid,SIGTERM);
                waitpid(cpid,NULL,0);
                break;
            }
        }
    }
    return 0;
}

木希叶乐 gold1100 课堂练习2.1:外部中断 实验总用时:00:03:43 实验环境倒计时:01:54:04 资源中心 数据集 nav 第2关:第一次时钟中断 700 任务要求 参考答案 记录 评论 任务描述 相关知识 准备阶段 使用 gdb 调试内核 跟踪分析时钟中断 中断/异常的恢复点分析 编程要求 测试说明 任务描述 分析版本1内核,找到第一次时钟中断的恢复点地址。 相关知识 为了完成本关任务,你需要掌握: 1.用 gdb 调试内核; 2.跟踪分析时钟中断; 3.中断/异常的恢复点分析。 准备阶段 本关卡的分析对象是版本1内核,可以基于前一关卡环境进行后续实验,如果重置实验环境则需要重新将版本1内核设置为分析对象,详见第一关的相关知识。 使用 gdb 调试内核 启动两个终端,在一个终端里切换到目录~/os/linux-0.11-lab,然后运行脚本 rungdb,以启动 bochs 虚拟机并等待 gdb 连接; 在另一个终端里切换到目录~/os/linux-0.11-lab,然后执行脚本./mygdb,以启动 gdb 并读入符号信息,跟踪到 main 函数入口。 跟踪分析时钟中断 在函数 do_timer(由时钟中断的处理函数 timer_interrupt 调用)处设置断点; 跟踪到该断点第 1 次出现; 中断/异常的恢复点分析 当一个中断/异常被 gdb 捕获时,通常正在运行中断处理程序,这时可以继续跟踪,直至回到恢复点指令。以时钟中断为例,为了从函数 do_timer 跟踪到恢复点,可以如下操作: 由上图可见时钟中断处理程序的入口是 timer_interrupt 函数。 跟踪到当前函数(do_timer)执行完毕返回到 timer_interrupt 函数; 跟踪到 timer_interrupt 函数(用汇编语言写的)末尾的 iret 指令; 通过单步执行命令 si 来执行该 iret 指令,返回到恢复点; 再通过反汇编命令:disas ,分析恢复点指令的地址。 关闭 gdb 调试: 在评测通关之后为了保证环境的正常,不影响下一关的操作,需要先输入 kill 指令关闭虚拟机,然后输入 quit 退出 gdb 调试。 编程要求 根据相关知识分析第一次时钟中断的恢复点的地址是多少,并将答案填写在/data/workspace/myshixun/恢复点指令地址.txt中。 测试说明 平台会对你的操作进行检测(要求反汇编显示恢复点处的指令),同时会对文档的内容进行检测。请完成操作并且填写文档内容之后再点击评测。 开始你的任务吧,祝你成功! 说点什么 resize-icon 测试结果 0/1 共有1组测试集,其中有1组测试结果不匹配。详情如下: 测试集1 消耗内存276.62MB 代码执行时长:0.1秒 —— 预期输出 —— —— 实际输出 —— 恭喜你,您的结果正确! 第一题答案正确[1049] Failed to execute script test2 恭喜你,您的结果正确! Traceback (most recent call last): File "test2.py", line 23, in <module> ValueError: substring not found 本关最大执行时间:20秒 本次评测耗时(编译、运行总时间):0.255 秒 显示/隐藏测试结果 上一关 下一关 run 评测
09-19
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值