前面我们学习了调度器的设计需要关注的几个点,在这里复习下: 吞吐量(对应的是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)的调度器。
约莫十五年前,当我刚刚开始参加工作时,赶上 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 的身影。
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)中加了需要时间的判断,各种情况的考虑,导致代码的阅读性很差,读起来很费劲。
今日更新了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 生成所有警告信息。
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语言写的。
,就停下来 -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 但是我们仔细看一下体积的差距太大了
前言 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.o –o hello gcc默认生成的二进制程序,是动态链接的,这点可以通过 file 命令验证。...-O0 -O1 -O2 -O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高 -w 不生成任何警告信息。 -Wall 生成所有警告信息。
并且,优先级一共就那么几个优先级,实际运行的时候,进程可不止有那么多个,所以优先级并不能真正代替进程是否先运行,并且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(
前言 在之前已经分享了 【Linux】vim的使用,这次来看看在云服务器上的编译器gcc。 2....这个是因为编译器版本的问题: 查看编译器的版本:gcc -v 版本不是最新的,不支持在for里面定义变量。...-o you.exe test.c -std=c99 在Linux中以.cpp和.cc结尾的都是c++代码 写一个简单的C++代码: #include using namespace...mv test.cxx test.txt 这里是不行的,Linux是不关心文件后缀的,但是编译器是关系。这里编译器就是把.txt当成文本文件了。...在Linux里面有,同样在windows里面也有。 在在Linux中库的真正的名字是把前缀lib去掉,去掉“.”后面的后缀。 所以这个就是c标准库。
我们还可以通过给编译器传递不同的宏值来进行代码的动态裁剪。 ...实例 : gcc –S test.i –o test.s -S选项只进行编译而不进行汇编,生成汇编代码。...: gcc –c test.s –o test.o 结果gcc的-c选项之后,生成了一个test.o的文件,文件内部就是二进制,但由于vim是文本编辑器,所以识别不出来。...实例 : gcc test.o –o test 如果自定义文件名称的话,会默认生成一个a.out的可执行文件。...gcc hello.o –o hello gcc 默认生成的二进制程序,是动态链接的,这点可以通过 file 命令验证 允许进行拷贝的库就是静态库,允许进行关联的库就是动态库。
编译(生成汇编) 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和库是如何连接的?
前面介绍了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来撤消该命令 重复某个命令:“.”
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
Linux是一个支持多任务的操作系统,而多个任务之间的切换是通过 调度器 来完成,调度器 使用不同的调度算法会有不同的效果。...Linux2.4版本使用的调度算法的时间复杂度为O(n),其主要原理是通过轮询所有可运行任务列表,然后挑选一个最合适的任务运行,所以其时间复杂度与可运行任务队列的长度成正比。...而Linux2.6开始替换成名为 O(1)调度算法,顾名思义,其时间复杂度为O(1)。...虽然在后面的版本开始使用 CFS调度算法(完全公平调度算法),但了解 O(1)调度算法 对学习Linux调度器还是有很大帮助的,所以本文主要介绍 O(1)调度算法 的原理与实现。...由于在 Linux 内核中,任务和进程是相同的概念,所以在本文混用了任务和进程这两个名词。
限制条件: 输入字符串的总长将会是 3n, 1 ≤ n ≤ 50; 输入字符串中的 “H” 总数将会是 2n; 输入字符串中的 “O” 总数将会是 n。...代码模板: class H2O { public H2O() { } public void hydrogen(Runnable releaseHydrogen) throws...由于题目中给的限制条件,已经明确说明了H是2n,O是n,所以我们不需要考虑无法构成水分子的情况。 我们分别定义H和O的信号量,都初始化为2个信号量。在每一次产生O的过程中,都需要等待产生了两个H。...import java.util.concurrent.Semaphore; class H2O { public H2O() { } private Semaphore...class H2O: def __init__(self): self.h, self.o = [], [] def hydrogen(self, releaseHydrogen
g++: 功能:g++是GCC套件中用于编译C++代码的编译器。它是gcc的C++编译器前端,通过调用GCC的后端来生成目标代码。...⭐gcc/g++的编译指令(以gcc为例) 首先可以查看一下自己的Linux上gcc的版本,确认是否有gcc编译器。...-O0,-O1,-O2,-O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高 -w 不生成任何警告信息。...静态库的文件扩展名通常为.lib(Windows)或.a(Unix/Linux)。...动态库的文件扩展名通常为.dll(Windows)或.so(Unix/Linux)。
我们到了简单编译器开发的最后一个阶段,也就是生成中间代码。...( "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
实例: 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++ 语言的源代码。
通过apt-get方式下载的Qt5.9的gcc编译器版本只是4.8.3,无法打开一些Qt5的库头文件,所以准备在Llinux下再安装一个gcc5.3.0。...参考: DamonXu-博客园-linux编译安装gcc5.3.0 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/167411.html原文链接:https://javaforall.cn
1、点击[命令行窗口] 2、按<Enter>键 3、点击[命令行窗口] 4、按<Enter>键
领取专属 10元无门槛券
手把手带您无忧上云