软件包和软件包管理器, 就好比 “App” 和 “应用商店” 这样的关系
在window下我们下载软件的时候可以使用软件市场下载软件,那么在linux中下载软件呢?
答案是yum
linux软件下载有三种方式:
1️⃣ 源码安装:将软件源代码进行编译
2️⃣ rpm安装:利用linux内置的安装包安装:类型安卓的apk文件
3️⃣ yum安装: 自己考虑依赖关系,不需要人处理
第一和第二中安装方式安装需要大量的其它依赖文件,而yum就像一个软件管家。
指令:yum list
功能:把linux可以安装的软件全部以list的方式列出来
指令:sudo yum install ……
输入sudo yum install figlet
后看看效果:
指令:sudo yum remove ……
卸载掉刚刚的软件:
1️⃣ 命令模式:这个模式下可以控制光标的移动,可以进行字符的删除,复制,粘贴,替换等命令。正常模式下按i即可进行插入模式
2️⃣ 插入模式:可以做文字的输入,这个模式下与windows下的txt文件编辑没有区别!直接用就行了!按esc即可退出到正常模式
3️⃣ 底行模式:输入冒号进入(即shift+;
)可以进行文件的保存,退出,查找等其它指令
指令:vim + 文件名
功能:使用vim打开文件,如果没有该文件,会自己创建
输入i进入插入模式就可以写代码了:
如果我们要保存退出的话,就需要按esc进入底行模式了:输入wq即可保存和退出
插入模式
按「i」切换进入插入模式「insert mode」,按“i”进入插入模式后是从光标当前位置开始输入文件
按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字
按「o」进入插入模式后,是插入新的一行,从行首开始输入文字
从插入模式切换为命令模式
按「ESC」键
光标移动:
vim可以直接用键盘上的光标来上下左右移动,但正规的vim是用小写英文字母「h」、「j」、「k」、「l」,分别控制光标左、下、上、右移一格
批量注释:
1️⃣
ctrl + 「v」
2️⃣ 用「h」、「j」、「k」、「l」选择要注释部分
3️⃣ 按大写的「i」
4️⃣ 输入"//"
5️⃣ 按「Esc」
批量取消注释:
文本操作:
「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与“y”有关的复制命令都必须与“p”配合才能完成复制与粘贴功能
「yy」:复制光标所在行到缓冲区
「nyy」:例如,「6yy」表示拷贝从光标所在的该行“往下数”6行文字
「np」:粘贴n行
「u」:如果您误执行一个命令,可以马上按下「u」,回到上一个操作。按多次“u”可以执行多次撤销
「ctrl + r」: 撤销的恢复
「vs + 文件名」:多文件操作
「ctrl + ww」: 让光标跳转
这样就可以把一个文件的内容拷贝/剪切到另一个文件(「dd + p」)
:wq就可以退出分屏
我们知道,我们要显示行号需要手动输入set nu,每次进入都需要手动设置
那么,我们能不能刚进文件不需要指令,自动显示行号呢?
配置方法:在自己的家目录下文件夹中新建一个.vimrc(/etc目录下)
在新建的文件中写入指令就可以了。
推荐指令(一键配置):
curl -sLf https://gitee.com/HGtz2222/VimForCpp/raw/master/install.sh -o ./install.sh && bash ./install.sh
补充一点:任何配置只会改变自己,不影响别的用户
gcc是一款可以编译c语言代码的编译器,如果想编译c++代码可以使用g++
先写一个测试程序:
指令:gcc + 文件
运行方法是:
./xxxx
在学习gcc选项之前,我们先回顾一下c程序的编译过程
预处理:去注释,展开宏,头文件
编译:生成汇编代码
汇编:生成机器二进制代码
链接:通过链接函数和其它第三方库,生成可执行程序或库文件
预处理过程:
gcc -E test.c -o test.i
说明一下,gcc的 -o 选项可以把输出放在特定的文件,不用-o就会全部显示出来
编译过程:
生成汇编语言,这个过程会检查语法是否有错误
gcc -S test.i -o test.s
汇编过程,生成机器代码(乱码),生成可重定向目标文件,不能直接执行
gcc -c test.s -o test.o
我们还需要最后一步链接过程:链接
gcc test.o -o test
在linux中有两种库:
动态库:
.so
(windows是.dll
)
静态库:.a
(windows是.lib
)
而链接的过程就是把自己写的c程序和第三方库关联起来。
那么静态链接和动态链接有什么区别呢?
静态库是把库文件代码全部导入到我们要编译的程序中
动态库并没有这样做,而是在程序执行时再进行库链接
静态库占用内存很大,动态库占用内存小,可以节省系统开销
gcc test.c -o test -static
下载C静态库:
sudo yum install -y glibc-static
下载C++静态库:
sudo yum install -y libstdc+±static
首先要知道g++也能编译c语言
创建c++文件:
touch test.cpp
编译c++:
g++ test.cpp -o cpp
在vs下我们调试起来会很容易,但是gdb会比较麻烦。
如果要调试时,我们在编译时必须让它生成调试信息(-g)(debug信息)
gcc testgdb.c -o testgdb -g
进入方法:
gdb xxx(可执行程序)
quit
或者ctrl + d
常用命令:
list/l 行号:接着上次的位置往下列,每次默认列10行
b(breakpoint): 设置断点
disable: 禁用断点
enable: 启用断点
d(delete) x :删除序号为x的断点,(不带x会删除所有断点)
r(run): 运行程序(到断点处)
n(next): 单条执行(window中的F10)
s(step): 单条(会进入函数)(window中的F11)
info b: 查看断点情况
display: 跟踪查看一个变量
undisplay: 取消跟踪
可以看到display展示的值每次都会显示出来,如果我们只想展示一次:
p(大小写都可以) + 变量
当我们确定这个函数没有问题的时候,我们可以直接跳出函数:
finish: 执行到当前函数返回(跳过函数)
假如在函数处有个断点,在函数下面有个断点,我们进入函数后想直接跳到下个断点:
continuing: 跳到下个断点处
而如果在一个函数内我们想跳过一段代码:
until + 行数: 跳到指定行
首先要知道make是一个指令,Makefile是一个文件。
他们共同形成可执行程序。
通常在一个大型项目中,通常需要编译大量的源文件,我们又不可能一条一条的用gcc编译我们的makefile就可以实现一次性编译,只要设置好对应文件的依赖关系即可。
什么是依赖关系呢?
gcc test.c test
其中test就依赖于test.c
我们先在当前项目文件夹下新建一个名叫Makefile的文件,对其进行编辑
格式:
可执行程序:依赖文件
gcc 文件 -o 程序
我们发现我们使用make的时候后面不用加东西,而clean得make clean,这是为什么?
make扫描makefile文件的时候,默认只生成一个目标依赖关系,一般是第一个。
所以我们通常把生成可执行程序的步骤放在最前面,再往下解决依赖问题
而.PHONY
又是什么呢?
.PHONY
修饰对应的符号(伪目标)总是可执行。
$@ 表示依赖关系中的目标文件(冒号左边)
$^ 表示文件列表(冒号右边)
符号会自己替换,跟上面展示的一样。
纸上得来终觉浅,绝知此事要躬行。