首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux O(n)调度器

前面我们学习了调度器的设计需要关注的几个点,在这里复习下: 吞吐量(对应的是CPU消耗型进程) 响应速度(对应的是IO消耗型进程) 公平性,确保每个进程都可以有机会运行到 移动设备的功耗 Linux中调度器的设计...实时进程采用两种调度策略SCHED_RR或者SCHED_FIFO 普通进程采用nice值进行动态调整普通进程的优先级 经常睡眠的进程尝试增大下优先级,经常长占CPU的适当减少优先级 本节我们先来学习Linux...早期的调度算法的设计,先从最早的调度器算法开始,此调度器时间复杂度是O(n),所以也可以称为O(n)调度算法。...我们选择的内核版本是linux-2.4.19。 O(n)调度器的实现原理 O(n)代表的是寻找一个合适的进程的时间复杂度。...总之O(n)调度器有很多问题,不过有问题肯定要解决的。所以在Linux2.6引入了O(1)的调度器。

3.4K20

谈谈调度 - Linux O(1)

约莫十五年前,当我刚刚开始参加工作时,赶上 Linux 发布划时代的 2.6 内核。在这个大家都翘首期盼的内核版本中,最令人兴奋的便是 O(1) scheduler。本文来谈谈这个算法是如何实现的。...2.4 scheduler 的问题 Linux 2.4 scheduler 支持 SMP(Symmetric Multi-Processing),然而,由于只用一个 global runqueue,各个...谈到搜索,大家第一反应是 hash table 是 O(1) 时间复杂度的。然而,它在最坏情况下是 O(N) 的。除此之外,没有任何算法能在最坏情况下 search 也是 O(1)。...linked list,stack,queue 在平均和最坏情况下都是 O(1),而大家脑海里的 hash table,同样的,虽然平均是 O(1),但最坏情况是 O(N)。...在其刚问世时,很多 linux 发行版就迫不及待将其移植回 2.4 kernel。而程序君整个职业生涯中接触过的一些调度器中,都能见到 bitarray + priority queue 的身影。

1.8K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux O(1)调度器

    O(n)调度器的种种问题,linux内核社区则在2.6内核版本引入了O(1)调度器,当然了引入的目的也正是要解决O(n)调度器面临的问题。...我们这片文章以Linux2.6.2版本来学习,在Linux内核文档中有一篇关于O(1)调度器的目的,如何设计的,以及实现有一个详细的介绍:sched-design.txt文档,有兴趣的可以去阅读。...从以上几点来看,可以看出O(1)的算法的改进都是针对O(n)算法存在的问题来修改的。...总结: O(1)调度器的引入主要是为了解决O(n)调度器的不足 O(1)调度器在赏罚机制上比O(n)调度器考虑的因素比较多,不再时像O(1)那样直接考时间片的大小来调度 但是O(n)和O(1)调度算法上核心还是通过判断一个进程的行为...如果去看O(1)调度器的实现,没有O(n)算法那么简单明了,O(1)中加了需要时间的判断,各种情况的考虑,导致代码的阅读性很差,读起来很费劲。

    2.9K21

    Linux编译器-gccg++

    今日更新了Linux编译器gcc、g++的内容 欢迎大家关注点赞收藏⭐️留言 编译器-gcc/g++ 我们直接用自带的gcc编译器会编译不了,因为当前版本太低了,有些语法不支持。...此时需要带个选项 -std=c99,让他支持c99标准就可以了,如下图: -o 选项后面接的是生成的目标文件的名字,即指定生成文件的名称。...3种常见c++后缀 .cc和.cpp都是指c++,需要用g++编译器,如果用gcc编译器就会报错。如果想支持更高的语法特性,可以加上 -std=c++11 的选项。g++也可以编译c语言程序。...实例: gcc –S hello.i –o hello.s 汇编(生成机器可识别代码) 汇编阶段是把编译阶段生成的“.s”文件转成目标文件 读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了...-O0 -O1 -O2 -O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高 -w 不生成任何警告信息。 -Wall 生成所有警告信息。

    10710

    LinuxLinux编译器gccg++的使用

    gcc test.c -E -o test.i /usr/include/stdio.h //linux下的头文件路径 C:\Program Files\Microsoft Visual Studio\...最后,为了方便大家记忆指令的选项和生成的文件后缀名,这里教一下大家如何去记,ESc正好就是退出键,iso是镜像文件的后缀名 4.链接(你写的代码 + C标准库的二进制代码 ==> 生成可执行的二进制程序...劣势:形成的可执行程序体积太大,网络、磁盘、内存的资源占用量大, 2.动态链接 通过编译器内部的链接器,来链接标准函数库,值得注意的是,动态链接的时期是在程序运行的时候,如果程序需要链接,链接器就会链接标准函数库...windows下动态库后缀为.dll静态库后缀为.lib 在安装vs2022时,我们安装的不仅仅是编译器本身,还要安装标准库的.h文件,以及标准动静态库等 5.Linux的大部分命令就是用C语言写的...大家需要有这个认识,Linux中大部分指令都是用C语言写的。

    2.2K11

    LinuxLinux编译器-gccg++使用

    ,就停下来 -o:指明形成的临时文件名称(.i) 头文件的展开 此时生成test.i,我们用vim进入test.i,在利用底行模式vs test.c: 同时,在预处理阶段完成了宏替换、去注释以及条件编译...: 条件编译的生效(宏的命令行定义) 可以向编译器传参来保证宏在命令行中定义 2.编译 在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查无误后,gcc...用户可以使用“-S”选项来进行查看,该选项只进行编译而不进行汇编,生成汇编代码 把C转换成汇编 gcc -S test.i -o test.s S:从现在开始,进行程序的翻译,做完编译工作,变成汇编之后...ESc 而生成的iso(就是镜像),方便记忆。...**这个库的位置: Linux下默认形成可执行程序,默认使用的是动态库 /lib64/libc-2.17.so静态库 生成静态链接 生成可执行程序后面要加上-static 但是我们仔细看一下体积的差距太大了

    2.1K30

    Linux编译器-gccg++

    前言 gcc/g++是Linux中的编译器,vim是Linux中的编辑器。要想将代码运行起来还需要编译才可实现。 本篇文章,主要通过预处理、编译、汇编、链接来介绍gcc/g++。...编译 在VS中,编译器会检查语法是否有错误,如果没有错误,才会编译成汇编语言。Linux下的gcc/g++也是一样。...指令: gcc -S test.i -o test.s 生成二进制文件 汇编 汇编是生成机器可识别的代码,汇编阶段是把编译阶段生成的“.s”文件转成目标文件 指令:gcc -c test.s -o test.o...完成了链接之后,gcc 就可以生成可执行文件,gcc hello.oo hello gcc默认生成的二进制程序,是动态链接的,这点可以通过 file 命令验证。...-O0 -O1 -O2 -O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高 -w 不生成任何警告信息。 -Wall 生成所有警告信息。

    16710

    初识Linux · O(1)调度算法

    并且,优先级一共就那么几个优先级,实际运行的时候,进程可不止有那么多个,所以优先级并不能真正代替进程是否先运行,并且nice值也是影响进程的运行,这一切,构成了一个新的专题,即Linux中的O(1)调度算法...O(1)调度算法 正式开始之前,我们不妨整理一下,有多少个问题: 1. 随着进程的增多,进程排队的时间是否会越来越多,甚至导致运行不了? 2. 优先级一定是越小就一定会先运行吗?...3. nice值影响优先级的区间为什么只有40个值 这么多问题的切入点只有一个,即Linux源码中的一个结构:runqueue 这是解决问题的关键。...根据上图,array[0]中有一个140个空间的queue,还有一个bitmap[5],因为这两个变量的存在,所以Linux的调度是分时操作的,保证了一定的公平性,还有一种操作是实时操作,实时操作的例子比如出租车...当某个队列中一个进程都没有了,比如active中没有进程了,那么active和expired交换队列,此时acitve指向的即活跃,即原来过期的进程变成了活跃进程,活跃的进程变成了过期的进程,这个过程,就被成为O(

    6410

    Linux编译器-gccg++使用

    编译(生成汇编) 3. 汇编(生成机器可识别代码) 4....连接(生成可执行文件或库文件) 2. gcc如何完成 格式 gcc [选项] 要编译的文件 [选项] [目标文件] 预处理(进行宏替换) 编译(生成汇编) 汇编(生成机器可识别代码) 连接(生成可执行文件或库文件...就可以编译了,相当于把a.out重命名了 1、只进行预处理:gcc -E mycode.c -0 mycode.i,(预处理后干净的C语言) 2、变成汇编语言(编译)gcc -S mycode.i -o ...mycode.s(将汇编工作做完,就停下来) 3、汇编(生成机器可以识别代码)gcc -c mycode.s -o mycode.o,(mycode.o是目标文件,将会边工作做完,就停下来了),.obj...4、连接,gcc mycode.o -o mytest后,再./mytest可以编译成功,连接过程将可重定位目标二进制和库进行连接形成可执行程序。键盘上的Esc方便记忆 .o和库是如何连接的?

    9210

    linux(五)之vi编译器

    前面介绍了linux的常用命令和对文本的操作,接下来我将对大家领略一下vi编译器的强大功能。 希望大家觉得写的还不错的话可以点个“推荐”哦!...一、vim/vi编译器简介 Vim/Vi是一个功能强大的全屏幕文本编译器(Full Screen Text Editor),是Linux平台上最常用的文本编译器 用于建立、编辑、显示文本文件(linux...1.2、插入模式(输入模式)   当用户在编辑模式下键入i/a/o等命令之后,可进入插入模式。在该模式下,用户随后输入的,除Esc之外的任何字符均将被看成是插入到编辑缓冲区中的字符。...在光标的右边插入文本 输入A,在一行的结尾处添加文本  3.2.2、插入     通过在命令模式下输入i,在光标的左边插入文本 通过在命令模式下输入I,在行首插入文本 3.2.3、插入新行     输入o,...在当前光标位置下面打开一行 输入O,在当前光标位置上面打开一行 3.3、撤销更改 撤消前一个命令:在最后一个命令之后立即输入u来撤消该命令     重复某个命令:“.”

    3K80

    cmake 生成Makefile时指定cc++编译器

    https://blog.csdn.net/10km/article/details/50444715 linux下在使用cmake生成Makefile的时候,如果不指定编译器,则默认是使用系统原生的编译器..., 当操作系统中安装了新的版本的编译器,多个版本编译器共存的时候,如果想使用新版本的编译器,在cmake生成Makefile的时候就需要指定编译器。...不论环境变量$PATH怎么设置,cmake在生成Makefile时,如果不指定编译器生成的Makefile都会调用/usr/bin下的g++/gcc。 所以这种情况下必须指定编译器。...在这里填写指定c/c++编译器的路径 ? shell脚本 那么如果要在脚本中调用cmake生成Makefile时,应该如何写脚本呢? #!.../build ## 保存当前路径位置,切换到BUILD_FOLDER pushd $BUILD_FOLDER ## 生成 Makefile, cmake "`dirs +1`" $GXX_PATH -G

    7.4K10

    Linux进程调度之 - O(1)调度算法

    Linux是一个支持多任务的操作系统,而多个任务之间的切换是通过 调度器 来完成,调度器 使用不同的调度算法会有不同的效果。...Linux2.4版本使用的调度算法的时间复杂度为O(n),其主要原理是通过轮询所有可运行任务列表,然后挑选一个最合适的任务运行,所以其时间复杂度与可运行任务队列的长度成正比。...而Linux2.6开始替换成名为 O(1)调度算法,顾名思义,其时间复杂度为O(1)。...虽然在后面的版本开始使用 CFS调度算法(完全公平调度算法),但了解 O(1)调度算法 对学习Linux调度器还是有很大帮助的,所以本文主要介绍 O(1)调度算法 的原理与实现。...由于在 Linux 内核中,任务和进程是相同的概念,所以在本文混用了任务和进程这两个名词。

    4.8K81

    自己动手写编译器:中间代码生成1

    我们到了简单编译器开发的最后一个阶段,也就是生成中间代码。...( "lexer" ) type ID struct { /* 该节点没有实现Gen,Reduce(),这意味着编译器遇到语句:"a;","b;"等时会直接越过 不生成任何中间代码...具体逻辑为当编译器遇到语句 a + b 就会生成Op节点, 那么a + b对应一个Arith节点,它对应child对象, 执行child.Gen()会生成中间代码对应的字符串...()函数,当编译器遇到语句”a+b”或者”a-b”时就会生成一个Op节点,同时创建对应的子Arith节点,在生成中间代码时,先调用Arith的Gen函数生成代码字符串” a + b” 或是 “a - b...”,然后创建一个临时寄存器变量t,最后生成中间代码: t = a + b 或者是: t = a - b 下面我们看节点Arith的实现,当编译器读到”a+b”这类语句时除了创建Op节点外也会创建Arith

    71310

    linux学习指南】Linux编译器 gcc和g++使用

    实例: gcc –S hello.i –o hello.s 生成汇编代码: 汇编(生成机器可识别代码) 汇编阶段是把编译阶段生成的“.s”文件转成目标文件 读者在此可使用选项“-c”就可看到汇编代码已转化为...“.o”的二进制目标代码了 实例: gcc –c hello.s –o hello.o 链接(生成可执行文件或库文件) 在成功编译之后,就进入了链接阶段。...动态库: .so (linux).dll(windows) 静态库: .a (linux).lib 最后的答案是:系统把这些函数实现都被做到名为 libc.so.6 的库文件中去了,在没有特别指定时...O0 O1 O2 O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高 w 不生成任何警告信息。 Wall 生成所有警告信息。...总结 gcc 和 g++ 是 GNU Compiler Collection (GCC) 中的两个编译器,分别用于编译 C 和 C++ 语言的源代码。

    17610
    领券