★ Linux ★ 基础开发工具的使用(上)

★ Linux ★ 基础开发工具的使用(上)

Ciallo~(∠・ω< )⌒☆ ~ 今天,我将和大家一起学习 linux 基础开发工具的使用~

52fc8aaee38e4b30b3305fc1ab3a99e5.jpeg

目录

壹  Linux编辑器 - vim使用

1.1 vim的基本概念

1.2 vim正常模式命令集

1.2.1 插入模式

1.2.2 移动光标命令

1.2.3 编辑命令

1.3 vim末行模式命令集

贰  Linux编译器 - gcc/g++使用

2.1 gcc如何完成

2.2 几个小问题

2.2.1 条件编译

2.2.2 为什么要编译成汇编文件

2.2.3 动静态库是什么

2.2.4 解决sodu报错

叁  Linux项目自动化构建工具-make/Makefile

3.1 初识makefile

3.2 .PHONY

3.3 完整的依赖关系

3.4 makefile中的写法

3.4.1 第一个版本

3.4.2 第二个版本

3.4.3 最终版本

~ 完 ~


壹  Linux编辑器 - vim使用

1.1 vim的基本概念

vim主要有三种模式,分别是命令模式插入模式底行模式

  • 命令模式:控制屏幕光标的移动,字符、字或行的删除,移动复制某区段及进入Insert mode下,或者到 last line mode。
  • 插入模式:只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。该模式是我们后面用的最频繁的编辑模式。
  • 底行模式:文件保存或退出,也可以进行文件替换,找字符串,列出行号等操作。 在命令模式下,shift+: 即可进入该模式。要查看你的所有模式:打开vim,底行模式直接输入。

模式的切换:

20b636621cf343909ac119ba9b25b5f3.jpeg

1.2 vim正常模式命令集

★  命令前加数字能更快的进行批量操作 ~

1.2.1 插入模式

  • 按「i」 进入插入模式「insert mode」从光标当前位置开始输入文件;
  • 按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字;
  • 按「o」进入插入模式后,是插入新的一行,从行首开始输入文字。

1.2.2 移动光标命令

  • 按「h」、「j」、「k」、 「l」:控制光标左、下、上、右移一格 ~
  • 按[gg]:进入到文本开始 ~
  • 按[shift+g]:进入文本末端 ~
  • 按「$」:移动到光标所在行的行尾 ~
  • 按「^」:移动到光标所在行的行首 ~
  • 按「w」:光标跳到下个单词的开头 ~
  • 按「e」:光标跳到下个单词的字尾 ~
  • 按「b」:光标回到上个单词的开头 ~

1.2.3 编辑命令

复制与黏贴与剪切

  • 「yy」:复制光标所在行 ~
  • 「p」:将缓冲区内的字符贴到光标所在位置 ~
  • 「dd」:剪切并删除光标所在行 ~
  • 「x」:剪切并删除光标所在位置后面的一个字符 ~
  • 「X」:剪切并删除光标所在位置前面的一个字符 ~

撤销

  • 「u」:撤销历史操作 ~
  • 「ctrl + r」: 撤销u的操作 ~

一旦退出文件编辑,无法再进行撤销了~ 没有退出都可以撤销 ~

替换

  • 「r」:替换光标所在处的字符 ~
  • 「R」:【替换模式】替换光标所到之处的字符,直到按下「ESC」键为止 ~
  • 「shift + ~」:小写改大写 ~

查找

  • 「#」:选中单词 ~
  • 「n」:批量查找 ~

批量注释

  • ctrl+v 进入【V-BLOCK模式】 ~
  • (n+) h j k l G 选择要注释行 ~
c5a1e7f61a1747828df40095145f2add.png
  • shift+i 进入【插入模式】,输入第一行的 // ~
b3d7035bbd58460f95d4ff43174c460d.png
  • esc退出【插入模式】 ~
be3a3cdedb9449c6815f76166361b268.png
  • 完成 ~

1.3 vim末行模式命令集

  • 「w」: 文件保存 ~
  • 「q」:退出vim ~
  • 「q!」:强制退出vim ~
  • 「wq」:退出并保存文件 ~
  • 「set nu」:列出行号 ~
  • 「!command」:执行命令 ~
  • 「%s/dst/src/」:批量替换 ~
  • 「vs 文件」:分屏 ~
  • 「ctrl+ww」:切换分屏 ~


贰  Linux编译器 - gcc/g++使用

2.1 gcc如何完成

gcc [选项] 要编译的文件 [选项] [目标文件]

1. 预处理(进行宏替换)

  • 预处理功能主要包括宏定义,文件包含,条件编译,去注释等 ~
  • 预处理指令是以#号开头的代码行 ~
  • 选项“-E”:开始进程程序翻译,预处理完后就停下来 ~
  • 选项“-o”是指目标文件,“.i”文件为已经过预处理的C原始程序 ~
gcc –E hello.c –o hello.i

2. 编译(生成汇编)

  • 在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查无误后,gcc 把代码翻译成汇编语言 ~
  • 选项“-S”:开始翻译,编译完后就停下来 ~
gcc –S hello.i –o hello.s

3. 汇编(生成机器可识别代码)

  • 汇编阶段是把编译阶段生成的“.s”文件转成目标文件 ~
  • 读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了 ~
gcc –c hello.s –o hello.o

4. 链接(生成可执行文件或库文件)

  • 在成功编译之后,就进入了链接阶段 ~
gcc hello.o –o hello

2.2 几个小问题

2.2.1 条件编译

64f95589148d49f08b6918c4a1443f60.png

命令行级别的宏定义:

gcc test.c -o test -DM gcc test.c -o test -DM=100

预处理的本质就是修改编辑我们的文本代码~

-DM就是再文本文件中加入#define M 100这样的字符串~

条件编译的作用:

  • 软件进行专业度,收费情况进行区分,使用条件编译,可以进行代码动态裁剪~
  • 内核源代码也是采用条件编译进行代码裁剪~
  • 开发工具,应用软件不同平台下的使用~

2.2.2 为什么要编译成汇编文件

程序的发展是从二进制->汇编语言->c语言->C++/JAVA等。每个阶段都经过了几十年的发展,c语言出现时汇编语言已经很成熟了,把c语言翻译成汇编语言再转换成二进制要比直接翻译成二进制容易得多~

每个语言的发明都要有对应的编译器使他可以翻译成汇编语言,那汇编语言怎么编译成二进制呢?首先在汇编语言出现后,先要发明一个二进制版的编译器,然后用汇编语言写一个汇编编译器,用二进制版的汇编编译器编译一下汇编写的汇编编译器,最后二进制版的就可以不要了,直接用汇编版的进行编译,这就是编译器的自举过程~

2.2.3 动静态库是什么

  • 动态库:Linux (.so)   windows (.dll)
  • 静态库:Linux (.a)     windows (.lib)

库是一套方法或者数据集,为开发提供最基本的保证(基本接口,功能,加速我们的二次开发)~

Linux下的C语言库为 libc.so 和 libc.a ,库的名字为去掉前缀lib和后缀.so/.a后剩余的。

动态库:把动态库内部实现的方法和我们自己的程序链接起来,让我们自己的程序能在库中找到方法,形成可执行程序,动态库在执行库中的方法时需要跳转到库中执行,完了再返回。

根据地址的替换来定位~

动态链接的图示:

250b29f66b11444bbe725fcd5474e1fc.png
3feb156ccfd8409eb6cdbb3ab0a8df1e.jpeg

静态链接就是把库里的实现拷贝一份到我们自己的代码中,用时调用自己这份实现。静态库只有在链接时有用,一旦形成可执行程序,就不需要静态库了~

动静态库对比:

  • 动态库形成的可执行程序体积一定很小~
  • 可执行程序堆静态库的依赖度小,动态库不能缺失~
  • 程序运行需要加载到内存,静态链接的会在内存中出现大量的重复代码~
  • 动态链接比较节省内存和磁盘资源~

ldd命令 - 显示所用库~  c程序默认动态链接

f7161f595c93483f8da743a39b7bb541.png

file命令 - 具体查看类型

8d7e83ab5b054e34afc998d96e3b9bfc.png
ccb4234c1fe4415dbec9a64a7b8bc351.png

如果想要静态链接:

2d965eb145e54dd9b577a8917fc5c154.png
5fd161a2faf94f65991f1042c78bb8ff.png

静态链接的可执行文件会大很多~
C++的情况:

d0f54b2986e94a0dad869b59aca84d80.png

动态库(共享库)的本质就是把语言层面的公共代码在内存中只出现一份~

2.2.4 解决sodu报错

fc0b089f32e54c44acd13ca4a54c0b95.png

普通用户在sudo时可能会出现以上报错~

解决步骤:

  • su -
  • 输入root密码
  • vim /etc/sudoers
  • :wq! 强制退出
  • ctrl+d 退出root

找到位置加入:

98854433575f48518a55f13a0d080b68.png

然后就完成辣~

f7c7ac5a7f8048aca8c5f3e314149d20.png

叁  Linux项目自动化构建工具-make/Makefile

3.1 初识makefile

make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。

makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。

  • touch Makefile
  • vim Makefile
0f8ec211c677482ca7850b60693e43e7.png

第一行为依赖关系 ~
第二行为tab + 依赖方法 ~

42983d7d69bd44b9a04542005f3c078d.png

上图为使用makefile的方法 ~

84b151ed4a914e0ebca5b27b9ccb5883.png

make命令扫描makefile文件的时候,从上向下扫描,默认形成第一个目标文件  ~

3.2 .PHONY

9c8afb1c510c490287f8f14e3e0250c7.png
93658ee3fca841aebb10ebbdb70448a5.png

.PHONY修饰的每次编译都执行~(本质上是说忽略判断新旧问题

而一般来说gcc编译的不建议加.PHONY修饰,如果源文件不改动,编译就不会执行~

58edec2219ba4994a7f7696276bc5fcd.png

Modify时间是作为知道bin和.c新旧的标准 ~

4a45a82935814e4a9400f380c8015f68.png

3.3 完整的依赖关系

d8f05deb193a4ed39b56c00f05d01d83.png
644f913b49d84e33972c6e3d11f7534c.png

3.4 makefile中的写法

测试方法:

f45a44d1a4c94f82b1c83568ef8b49a1.png

@符号让make不回显~

3.4.1 第一个版本

基于变量版的Makefile ~(类似于宏)

dc39e688f7d044ce968c4043e171f77e.png

BIN和SRC也可以优化掉~

fb74a902163942b19c8a5f20122b9ff3.png
69869a2dc7e64ecbb06e5f88f4778cb7.png

3.4.2 第二个版本

05afc1142b0f4b34b0b2772db6769f9d.png

如果有多个文件呢~

e58f79222fd542baa1d06b7919aa6820.png
8e36654e4e054389a75f25c4f97a8c8f.png

3.4.3 最终版本

a4b45792e5bc4384ad4442f25cd938f2.png
1ec65d9f74874f349a43154be1cb55e8.png
8c29e315f6a7448c825cd0b58d091eb9.png

~ 完 ~

2527de89e9a84e4985c92a24d22ce266.png

Read more

动态规划——分组背包(附带经典例题3个)

分组背包: 1.定义:给定一个整数m表示背包的容量,有n个货物可供挑选。每个货物有自己的体积,价值,组号。同一个组的物品只能挑选一件,所有挑选物品的体积总和不能超过背包容量。 怎么挑选货物能达到价值最大,返回最大价值。 2.dp[i][j]表示1~i组上,每组只能选一件商品(注意:i表示的是组,不是商品)容量不超过j的条件下的最大价值。 1)不要i组商品就满足条件——dp[i-1][j] 2)要i组商品,考虑要哪一件?全试!!! a:dp[i-1][j-a的体积]+a的价值 b:dp[i-1][j-b的体积]+b的价值 c:dp[i-1][j-c的体积]+c的价值 (注意:a,b,

By Ne0inhk
《算法题讲解指南:优选算法-滑动窗口》--13 水果成篮

《算法题讲解指南:优选算法-滑动窗口》--13 水果成篮

🔥小叶-duck:个人主页 ❄️个人专栏:《Data-Structure-Learning》 《C++入门到进阶&自我学习过程记录》《算法题讲解指南》--从优选到贪心 ✨未择之路,不须回头 已择之路,纵是荆棘遍野,亦作花海遨游 目录 13 水果成篮 题目链接: 编辑 题目示例: 解法(滑动窗口): 算法思路: 算法流程: C++代码演示:方法一(使用容器) C++代码演示:方法二(用数组模拟哈希表) 算法总结及流程解析: 结束语 13 水果成篮 题目链接: 题目示例: 解法(滑动窗口): 算法思路:       研究的对象是一段连续的区间,可以使用【滑动窗口】思想来解决问题。       让滑动窗口满足:窗口内水果的种类只有两种。       做法:右端水果进入窗口的时候,

By Ne0inhk
Flutter for OpenHarmony 实战:Material Color Utilities — 算法驱动的动态换肤

Flutter for OpenHarmony 实战:Material Color Utilities — 算法驱动的动态换肤

Flutter for OpenHarmony 实战:Material Color Utilities — 算法驱动的动态换肤 前言 随着 Flutter for OpenHarmony 进入全场景智慧时代,UI 的“个性化”与“自适应”成为了衡量应用质感的重要指标。Material Design 3 (M3) 引入了颠覆性的 动态颜色 (Dynamic Color) 系统,它可以从一张壁纸或用户的特定配色中提取出一整套和谐、对比度合格的主题。 你是否好奇:这些颜色是如何生成的?为什么生成的蓝色看起来既专业又不刺眼?答案就在 material_color_utilities 中。这是谷歌 M3 配色方案背后的核心算法库。本文将带你深入底层,由算法驱动鸿蒙应用的色彩革命。 二、M3 动态配色的核心黑科技 2.1 HCT

By Ne0inhk
优选算法《双指针》

优选算法《双指针》

在学习了C/C++的基础知识之后接下来我们就可以来系统的学习相关的算法了,这在之后的笔试、面试或竞赛都是必须要掌握的;在这些算法中我们先来了解的是一些非常经典且较为常用的算法,在此也就是优选出来的算法,接下来在每一篇章中我们都会来学习一种优选算法,并且在了解了算法原理之后接下来会通过几道算法题来巩固相应的算法原理。在每道算法题的讲解中都会通过题目解析——算法原理讲解——代码实现三步来带你完全吃透每道算法题,相信通过这一系列算法专题的学习,你的算法以及代码能力会有质的飞跃。接下来就开始本篇双指针专题算法的学习吧!!!  1.双指针算法 在之前数据结构链表和顺序表的学习当中我们就已经使用过了双指针的算法,就例如在删除数组当中的重复元素、判断一个链表是否为环、带环链表找出入环位置、找出链表的中间节点等算法题中我们就已经使用到双指针的算法思想,那么双指针的算法思想具体是什么呢?接下来就来详细的了解看看 常见的双指针有两种形式,一种是对撞指针,⼀种是左右指针。 对撞指针:一般用于顺序结构中,也称左右指针。 • 对撞指针从两端向中间移动。⼀个指针从最左端开始,另⼀个从最右端开始,然后逐

By Ne0inhk