🐶博主主页:@ᰔᩚ. 一怀明月ꦿ
❤️🔥专栏系列:线性代数,C初学者入门训练,题解C,C的使用文章,「初学」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
总结一下:命令行参数,可以支持各种指令级别的命令选项的设置!终于理解历史学的指令,选项是什么关系了
🌸🌸🌸如果大家还有不懂或者建议都可以发在评论区,我们共同探讨,共同学习,共同进步。谢谢大家! 🌸🌸🌸