Linux第十五章

发布于:2024-04-30 ⋅ 阅读:(163) ⋅ 点赞:(0)

🐶博主主页:@ᰔᩚ. 一怀明月ꦿ 

❤️‍🔥专栏系列:线性代数C初学者入门训练题解CC的使用文章「初学」C++linux

🔥座右铭:“不要等到什么都没有了,才下定决心去做”

🚀🚀🚀大家觉不错的话,就恳求大家点点关注,点点小爱心,指点指点🚀🚀🚀

目录

进程运行

linux2.6内核的调度队列与调度原理

cpu运行队列

实时(Real-time)和分时(Time-sharing)

命令行参数

算术运算器

mytouch


进程运行

进程在cpu跑的时候,如果时间片到了,没有跑完的话,寄存器上下文数据就会保存在该进程的pcb中

本质:cpu寄存器的内容,保存到内存中

进程在cpu跑的时候,如果时间片到了,进程被剥离,cpu上的寄存器上下文数据不会被清空,只是下一个进程,在cpu上跑的时候,寄存器上的数据会被覆盖

如果进程在cpu跑之前,首先需要把进程pcb中的上下文数据加载到cpu中,如果这个进程第一次在cpu上跑,上下文数据为空。

linux2.6内核的调度队列与调度原理

cpu运行队列

 Linux中的优先级【60,99】:普通优先级

linux其实是有140个优先级的

linux中【0,99】不用管:做实时操作系统的

实时(Real-time)和分时(Time-sharing)

在Linux中,实时(Real-time)和分时(Time-sharing)是操作系统调度策略的两种常见类型。

实时调度: 实时调度是为了满足对任务响应时间要求严格的应用场景而设计的。实时任务通常具有固定的截止时间或优先级,并且必须及时得到处理。

分时调度: 分时调度是最常见的调度策略,它以时间片为单位,给每个任务分配一小段时间进行执行。Linux默认使用的调度策略就是时间片轮转调度算法。

分时调度策略适用于多用户、多任务的场景,在公平地分配CPU资源的同时,保证了系统的响应能力。而实时调度策略则更加重视对于实时任务的处理,并确保其满足截止时间要求。

请注意,实时任务为了满足其及时性的要求,可能会抢占分时任务的CPU时间,因此在使用实时调度策略时需要谨慎权衡。  

命令行参数

main函数可以传参数吗?

可以

int main(int argc,char *argv[])
{
        int i=0;
        for(;i<argc;i++)
        {
                printf("%d: %s\n",i,argv[i]);
        }
        //printf("hello world!\n");
        return 0;
}

//
[BCH@hcss-ecs-6176 10_19]$ ./myproc -a --b --help —version//一个大的字符串
//以空格作为分隔符,被分割了5个子串
0: ./myproc
1: -a
2: --b
3: --help
4: --version


argv是一个指针数组
[0]:保存的是./myproc字符串的地址
[1]:保存的是-a字符串的地址
[2]:保存的是--b字符串的地址
[3]:保存的是--help字符串的地址
[4]:保存的是—version字符串的地址
[5]:null

算术运算器

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(int argc,char *argv[])
{
        if(argc!=4)
        {
                printf("Use error \n Usage:%s op[-add|sub|mul|div] d1 d2",argv[0]);
                return 1;
        }
        int x=atoi(argv[2]);
        int y=atoi(argv[3]);
        int result=0;
        if(strcmp(argv[1],"-add")==0)
        {
                result=x+y;
                printf("%d+%d=%d\n",x,y,result);
        }
        else if(strcmp(argv[1],"-sub")==0)
        {
                result=x-y;
                printf("%d-%d=%d\n",x,y,result);
        }
        else if(strcmp(argv[1],"-mul")==0)
        {
                result=x*y;
                printf("%d*%d=%d",x,y,result);
        }
        else if(strcmp(argv[1],"-div")==0)
        {
                if(y==0)
                        printf("error:is not 0");
                else
                        printf("%d/%d=%d",x,y,x/y);
        }
        else
        {
                
                printf("Use error \n Usage:%s op[-add|sub|mul|div] d1 d2\n",argv[0]);


        }
        return 0;
}

[BCH@hcss-ecs-6176 10_19]$ ./myproc -add 20 10
20+10=30
[BCH@hcss-ecs-6176 10_19]$ ./myproc -sub 20 10
20-10=10
[BCH@hcss-ecs-6176 10_19]$ ./myproc -mul 20 10
20*10=200
[BCH@hcss-ecs-6176 10_19]$ ./myproc div 20 10
Use error 
 Usage:./myproc op[-add|sub|mul|div] d1 d2
[BCH@hcss-ecs-6176 10_19]$ ./myproc -div 20 10
20/10=2

mytouch

自己实现简易版的touch指令,mytouch

#include<stdio.h>
#include<stdlib.h>
int main(int argc, char* argv[])//argv中[0]是mytouch程序,[1]文件名
{
        if(argc!=2)
        {
                printf("error:\nusege:%s filename\n",argv[0]);
                return 1;
        }


        FILE* fp=fopen(argv[1],"w”);//这是c语言中创建文件的方法
        if(fp!=NULL)fclose(fp);
        return 0;
}

[BCH@hcss-ecs-6176 10_19_1]$ make
make: “mytouch”是最新的。
[BCH@hcss-ecs-6176 10_19_1]$ ./mytouch wcq
[BCH@hcss-ecs-6176 10_19_1]$ ll
总用量 20
-rw-rw-r-- 1 BCH BCH   67 10月 19 20:34 Makefile
-rwxrwxr-x 1 BCH BCH 8464 10月 19 20:38 mytouch
-rw-rw-r-- 1 BCH BCH  221 10月 19 20:38 mytouch.c
-rw-rw-r-- 1 BCH BCH    0 10月 19 20:43 wcq

总结一下:命令行参数,可以支持各种指令级别的命令选项的设置!终于理解历史学的指令,选项是什么关系了

🌸🌸🌸如果大家还有不懂或者建议都可以发在评论区,我们共同探讨,共同学习,共同进步。谢谢大家! 🌸🌸🌸 


网站公告

今日签到

点亮在社区的每一天
去签到