c语言-操作系统实验案例

简介:
题目一:进程控制(杀死子进程)
父进程创建两个子进程,等待ctrl+c信号杀死所有子进程。并打印:
Child Process1 is Killed by parent!
Child Process2 is Killed by Parent!
Parent Process is Exit now
 
代码:

#include<unistd.h>
#include<signal.h>
#include<sys/time.h>
#include<stdio.h>
int pid1,pid2;
void sig_alarm()

}
int main()
{
 if(signal(SIGINT,sig_alarm)==SIG_ERR)
   printf("Signal Error");
 pid1=fork();
 if(pid1>0)
 {
  pid2=fork();
  if(pid2>0)
  {  
   pause();  
   if(kill(pid1,SIGKILL)==kill(pid2,SIGKILL)==0)
    printf("ok\n");
   wait(0);
   wait(0);   
   printf("Parent Process is Exit now\n");   
  }
  else
  {
   signal(SIGKILL,sig_alarm);
   pause();
   printf("Child Process2 is Killed by Parent!\n");
  }
 } 
 else
 { 
  signal(SIGKILL,sig_alarm);
  pause();
  printf("Child Process1 is Killed by parent!\n");
 } 
}

题目二:进程间通信(非原创)
由子进程给父进程发送字符串,子进程一发送的字符串全转换为大写,子进程二全转换为小写。

#include <unistd.h>                                                                                                     

#include <signal.h>                                                                                                     

#include <stdio.h>                                

 

#include<stdlib.h>

void strupr(char *string,char *s_tr)

{

int i=0;

while(string[i]!='\0')

 {

        s_tr[i]= toupper(string[i]);

 i++;

 }

return ;

}

 

void strlwr(char *string,char *s_tr)

{

int i=0;

while(string[i]!='\0')

 {

        s_tr[i]= tolower(string[i]);

 i++;

 }

return ;

}                                                                   

int pid1, pid2;          // 定义两个进程变量

main( ) {

  int fd[2];

 char s_tr[80]="\0";

  char OutPipe[100], InPipe[100];           // 定义两个字符数组

  pipe(fd);                      // 创建管道

  while ((pid1 = fork( )) == -1);   // 如果进程1创建不成功,则空循环

  if (pid1 == 0)

     {                         // 如果子进程1创建成功,pid1为进程号

        lockf(fd[1], 1, 0);         // 锁定管道

        sprintf(OutPipe, "\n Child process 1 is sending message!\n");  // 给Outpipe赋值            

        write(fd[1], OutPipe, 50);  // 向管道写入数据

        sleep(5);                   // 等待读进程读出数据

        lockf(fd[1], 0, 0);          // 解除管道的锁定

        exit(0);                     // 结束进程1

     }

     else {

           while ((pid2 = fork()) == -1);            // 若进程2创建不成功,则空循环

           if (pid2 == 0)

              {

                lockf(fd[1], 1, 0);

                sprintf(OutPipe, "\n Child process 2 is sending message!\n");

                write(fd[1], OutPipe, 50);

                sleep(5);

                lockf(fd[1], 0, 0);

                exit(0);

              }

              else {

                     wait(0);                             // 等待子进程1 结束

                     read(fd[0], InPipe, 50);            // 从管道中读出数据

                     strupr( InPipe, s_tr);           //转化为大写

                     printf("%s\n", s_tr);            // 显示读出的数据

                     wait(0);                                // 等待子进程2 结束

                     read(fd[0], InPipe, 50);

                    strlwr( InPipe, s_tr);

                     printf("%s\n", s_tr);

                     exit(0);                           // 父进程结束

                   }

           }

}


题目三:页面置换原理模拟

自己模拟计算机的指令地址访问(50%顺序执行,25%前地址访问25%后地址访问)。

模拟置换算法:

 

代码:


#include "stdio.h"

#include "stdlib.h"

#include "conio.h"

#include "alloc.h"

#include "io.h"

#include "time.h"

//pages

/*memory pages*/

int mp[4]={-1,-1,-1,-1};

//OPTIMAL memory pages

int opg[4]={0,0,0,0};

//LRU memory pages

double lpg[4]={0,0,0,0};

//Improved CLOCK memorypages

struct clock

{

 int mp;

 int a;

 int m;

 struct clock *pre;

 struct clock *next;

}cpg[4]={

 {0,0,0,&cpg[3],&cpg[1]},

 {1,0,0,&cpg[0],&cpg[2]},

 {2,0,0,&cpg[1],&cpg[3]},

 {3,0,0,&cpg[2],&cpg[0]},

},*chead=&cpg[0],*tail=&cpg[3];

/*instructions*/

struct op

{

 int id;

 int pid;

 int offset;

 struct op *pre;

 struct op *next;

}*cd,*head,*t;

// cd:initialized address flow and set value=end of the address flow

// head:set value=head of the address flow

// t:operation var used in arithmetic calculate

 

/*get next m*/

int getM(int m,int oid)

{

 if(m==-1)

  return random(319);

 if(oid%2)

  return m+1;

 else

 {

  if(oid/2%2)

   return random(m);

  else

   return random(319-m)+m;

 }

}

 

//if not in memory return 1

int notInMemory(int m)

{

 int i;

 for(i=0;i<4;i++)

 {

  if(mp[i]>=0&&(m-mp[i]*10)>0&&(m-mp[i]*10)<10)

  return 0;

 }

 return 1;

}

//optimal arithmetic

void optimal()

{

 int j=0;

 int n=0;

 int m=0;

 struct op *in=t->next;

 for(;in->id<320;in=in->next)

 {

  m=in->pid*10+in->offset;

  if(!notInMemory(m)&&n<3)

  {

   for(j=0;j<4;j++)

   {

    if(mp[j]==in->pid&&opg[j]!=1)

    {

     opg[j]=1;

     n++;

     break;

    }

   }

  }

 }

 for(j=0;j<4;j++)

 {

  //printf("pg[%d].sta=%d\t",mp[j],opg[j]);//test

  if(!opg[j])

   mp[j]=t->pid;

  opg[j]=0;

 }

}

 

//FIFO arithmetic

void FIFO()

{

 int i;

 for(i=0;i<4;i++)

 {

  mp[i]=mp[i+1];

 }

 mp[3]=t->pid;

}

 

//LRU arithmetic

void LRU()

{

 int i;

 int n=0;

 double goal=0;

 double k=lpg[0];

 for(i=1;i<4;i++)

 {

  if(k>=lpg[i])

  {

   k=lpg[i];

   n=i;

  }

 }

 goal=clock()+(double)1;

 while(goal>clock());//time sleep for 0.002

 lpg[n]=clock();

 mp[n]=t->pid;

}

 

//CLOCK arithmetic

void CLOCK()

{

 int i;

 int result=-1;

 struct clock *c=chead;

 for(i=0;i<4;i++)

 {

  if(!c->a&&!c->m)

  {

   result=c->mp;

   break;

  }

  c=c->next;

 }

 if(result==-1)

 {

  c=chead;

  for(i=0;i<4;i++)

  {

   if(!c->a)

   {

    result=c->mp;

    break;

   }

   c->a=0;

   c=c->next;

  }

 }

 if(result==-1)

 {

  c=chead;

  for(i=0;i<4;i++)

  {

   if(!c->a&&!c->m)

   {

    result=c->mp;

    break;

   }

   c=c->next;

  }

 }

 if(result==-1)

 {

  c=chead;

  for(i=0;i<4;i++)

  {

   if(!c->a)

   {

    result=c->mp;

    break;

   }

   c=c->next;

  }

 }

 mp[result]=t->pid;

 if(c==chead)

  chead=c->next;

 if(c!=tail)

 {

  c->pre->next=c->next;

  c->next->pre=c->pre;

  c->next=tail->next;

  tail->next->pre=c;

  tail->next=c;

  c->pre=tail;

  tail=c;

  c->a=0;

  c->m=0;

 }

}

 

void main()

{

 //operation id

 int oid=0;

 //the absolute address initialized from -1

 int m=-1;

 //fail page time

 int fpt=0;

 //only var

 int i,j,k;

 time_t now;

 //record address document

 FILE *f=fopen("address.txt","w");

 //initialize a time random seed

 randomize();

 //make address flow

 for(;oid<320;oid++)

 {

  //get address in the form of os

  m=getM(m,oid);

  //record address

  fprintf(f,"oid=%d\tm=%d\n",oid,m);

  //cd=(struct op *)malloc(sizeof(struct op));

  (*cd).id=oid;

 

  //ten instructions in one page

  (*cd).pid=m/10;

  (*cd).offset=m%10;

 

  //two-way queue

  cd->next=(struct op *)malloc(sizeof(struct op));

  cd->next->pre=cd;

  cd=cd->next;

 }

 fclose(f);

 cd->id=320;

 

 //get head

 head=cd;

 for(;;)

 {

  if((*head).id==0)

  break;

  head=head->pre;

 }

 

 //optimal arithmetic

 //start

 for(t=head;t->id<320;)

 {

  m=t->pid*10+t->offset;

  if(notInMemory(m))

  {

   fpt++;

   optimal();

  }

  t=t->next;

 }

 printf("Optimal arithmetic:\nHit number is %d\n Probability:%f%\n",fpt,100*((float)(320-fpt))/320);

 printf("****************************************************************************\n");

 //end

 

 //FIFO arithmetic

 //initializ vars

 fpt=0;

 for(i=0;i<4;i++)

 {

  mp[i]=-1;

 }

 //start

 for(t=head;t->id<320;)

 {

  m=t->pid*10+t->offset;

  if(notInMemory(m))

  {

   fpt++;

   FIFO();

  }

  t=t->next;

 }

 printf("FIFO arithmetic:\nHit number is %d\n Probability:%f%\n",fpt,100*((float)(320-fpt))/320);

 printf("****************************************************************************\n");

 //end

 

 //LRU arithmetic

 //initializ vars

 fpt=0;

 for(i=0;i<4;i++)

 {

  mp[i]=-1;

 }

 //start

 for(t=head;t->id<320;)

 {

  m=t->pid*10+t->offset;

  if(notInMemory(m))

  {

   fpt++;

   LRU();

  }

  else

  {

   for(i=0;i<4;i++)

   {

    if(mp[i]==m/10)

     lpg[i]=clock();

   }

  }

  t=t->next;

 }

 printf("LRU arithmetic :\nHit number is %d\n Probability:%f%\n",fpt,100*((float)(320-fpt))/320);

 printf("****************************************************************************\n");

 //end

 

 //Improved Clock arithmetic

 //initializ vars

 fpt=0;

 for(i=0;i<4;i++)

 {

  mp[i]=-1;

 }

 //start

 for(t=head;t->id<320;)

 {

  m=t->pid*10+t->offset;

  if(notInMemory(m))

  {

   fpt++;

   CLOCK();

  }

  else

  {

   for(i=0;i<4;i++)

   {

    if(mp[i]==m/10)

     cpg[i].a=1;

   }

  }

  t=t->next;

 }

 printf("Improved Clock arithmetic:\nHit number is %d\n Probability:%f%\n",fpt,100*((float)(320-fpt))/320);

 printf("****************************************************************************\n");

 //end

}

本文转自today4king博客园博客,原文链接:http://www.cnblogs.com/jinzhao/archive/2007/12/15/995833.html,如需转载请自行联系原作者
相关文章
|
4天前
|
Unix 编译器 Shell
[oeasy]python0033_先有操作系统还是先有编程语言_c语言是怎么来的
本文回顾了计算机语言与操作系统的起源,探讨了早期 Unix 操作系统及其与 C 语言的相互促进发展。Unix 最初用汇编语言编写,运行在 PDP-7 上,后来 Thompson 和 Ritchie 开发了 C 语言及编译器,使 Unix 重写并成功编译。1974 年 Ritchie 发表论文,Unix 开始被学术界关注,并逐渐普及。伯克利分校也在此过程中发挥了重要作用,推动了 Unix 和 C 语言的广泛传播。
25 9
[oeasy]python0033_先有操作系统还是先有编程语言_c语言是怎么来的
|
11天前
|
Oracle Java 关系型数据库
CentOS 7.6操作系统部署JDK实战案例
这篇文章介绍了在CentOS 7.6操作系统上通过多种方式部署JDK的详细步骤,包括使用yum安装openjdk、基于rpm包和二进制包安装Oracle JDK,并提供了配置环境变量的方法。
168 80
|
1天前
|
存储 数据挖掘 Linux
服务器数据恢复—Linux操作系统网站服务器数据恢复案例
服务器数据恢复环境: 一台linux操作系统服务器上跑了几十个网站,服务器上只有一块SATA硬盘。 服务器故障: 服务器突然宕机,尝试再次启动失败。将硬盘拆下检测,发现存在坏扇区
|
2月前
|
弹性计算 运维
阿里云操作系统智能助手OS Copilot实验测评报告
**OS Copilot 产品体验与功能反馈摘要** 运维人员发现OS Copilot易上手,文档清晰,助其高效排查故障(8/10分)。愿意推荐并参与开源开发。亮点在于知识问答,能快速筛选答案。相较于竞品,优点是新手友好、文档清晰,但功能扩展性待增强。期望增加系统错误排查与解决方案,并集成ECS等,以优化系统安装流程。
阿里云操作系统智能助手OS Copilot实验测评报告
|
2月前
|
弹性计算 运维 自然语言处理
阿里云操作系统智能助手OS Copilot实验测评报告
OS Copilot是阿里云Linux的智能助手,助于提升运维效率,通过学习用户习惯提供智能建议。开发者反馈其在DevOps场景中非常有用,给予10分帮助度评价。用户赞赏其命令执行功能,希望能扩展多命令执行和错误自动修正。与ACK、ECS等集成,可自动化部署和CI/CD流程。文档清晰,适合新手,用户愿意推荐并参与开源开发。
94 3
阿里云操作系统智能助手OS Copilot实验测评报告
|
2月前
|
弹性计算 运维 自然语言处理
阿里云操作系统智能助手OS Copilot实验测评报告
阿里云OS Copilot是一款专为Linux设计的智能运维助手,利用大语言模型提供自然语言问答、命令执行辅助和系统调优功能。软件维护工程师反馈,OS Copilot易于上手,文档清晰,对提升运维效率有显著帮助,评分10/10。其轻量级设计、准确的回答是主要优点,但可能在复杂场景下表现不足。用户期望扩展到更多Linux发行版,增加系统优化建议、代码优化和日志分析功能,并能与其他产品如ACK、ECS联动。希望能有异常处理提示和日志输出以增强问题定位。
104 14
|
2月前
|
人工智能 运维 自然语言处理
|
2月前
|
弹性计算 人工智能 运维
阿里云操作系统智能助手OS Copilot实验测评报告
**摘要:** 在阿里云与CSDN联合的OS Copilot测试中,一名学生体验者发现该智能助手是强大的编程学习工具,给予10分的帮助评价。尽管有新手上手难度和兼容性问题,他仍强烈推荐并有意参与开源开发。OS Copilot的亮点包括直接的交互式知识问答、编程辅助及命令执行。相比其他产品,其优点是简洁和准确性,但需改进新手教程。用户期待更多功能,如系统优化建议,扩大操作系统支持,并建议与阿里云产品如ACK、ECS集成,以提升运维效率。
103 12
|
2月前
|
弹性计算 运维 自然语言处理
阿里云操作系统智能助手OS Copilot实验测评报告
OS Copilot是Alibaba Cloud Linux基于大模型构建的操作系统智能助手,其旨在通过自然语言问答、辅助命令执行及系统运维调优等功能,提升用户对Alibaba Cloud Linux的使用效率。
|
2月前
|
弹性计算 运维 自然语言处理
阿里云操作系统智能助手OS Copilot实验测评报告
OS Copilot是针对Linux的智能助手,助力学习、运维及编程。用户界面直观,自然语言交互方便新手。官方文档详尽,但初次配置略复杂,适合学生和开发者。在提高代码编写和调试效率、系统学习上得分高,功能亮点包括代码生成、问答和命令执行。用户期待更多操作系统支持、自动错误分析和系统排查功能。
176 3