一、软件包管理器yum
1、yum概念
yum是一个软件下载安装管理的客户端,例如手机上的小米一应用商城。
那为什么我们推荐在Linux中用yum下载软件呢?
其实软件的安装有三种方式:源代码安装,rpm包安装,yum安装。
a、源代码安装
顾名思义就是把程序员写好的原生代码拿过来自己编译安装软件。但是这种方式是非常不方便的,因为源代码的编译环境因人而异,所以很有可能在你的环境下面程序无法编译。不仅如此,原生代码中也会用到大量的库,少装一个都会导致源代码无法编译。
b、rpm包安装
把原生代码在各种环境中编译号打包之后就是rpm包。
c、yum安装
yum在rpm包的基础上,帮使用者搞定软件包之间的依赖关系,例如源程序中要用到的库等。
2、yum操作
yum list | grep xxx 搜索软件
yum -y install xxx 下载软件
yum -y remove xxx 卸载软件
当然如果你是普通用户的话要指令提权。
在最后一列中base表示基本软件源,是稳定的。epel表示扩展软件源,不太稳定。
3、 补充知识
(1)yum是如何知道要去哪里安装我们需要的软件?
其实在我们机器内部内置了一些服务器地址链接,在yum要下载文件时,他会连接对应的服务器,下载对应软件。
(2)yum的配置
首先,yum会根据/etc/yum.repos.d/该路径下配置文件来构成自己的下载链接。一般机器内置链接是centos官网,软件链接指向国外,yum下载会变慢,所以要配置,本质就是修改文件或内容。
二、文本编辑器vim
1、vim基础知识
vim本质就是类似于记事本的多模式文本编辑器,用来编辑文本。
vim常见的模式有四种:插入模式,命令模式,底行模式,替换模式。
2、常见模式介绍
(1)命令模式
允许使用者通过命令进行文本编辑控制。
(2)插入模式
可以修改文本内容。
(3)底行模式
用来让vim进行包括但不限于与shell进行交互。
(4)替换模式
可以对文本内容进行替换。
刚打开vim时处在的模式是命令模式。
3、模式切换
4、各个模式中的常见操作
(1)命令模式
yy:复制光标所在行
nyy:从当前光标位置开始,连续复制n行
dd:剪切当前行
ndd:剪切当前光标位置以下n行
p:粘贴
np:粘贴n次
u:撤销操作
ctrl r:对上一次的撤销操作进行撤销
shift 4($):光标移动到所在行结尾
shift 6(^):光标移动到所在行开头
gg:光标到文本开头
shift g:光标到文本结尾
n shift g:光标定位到文本第n行
h j k l:分别是左下上右移动光标,带上n就是重复n次
w:按单词进行光标后移
b:按单词进行光标前移
shift `(~):单词进行大小写切换
x:删除光标之后一个字符,可以带n
shift x:删除光标之前一个字符,可以带n
r:对光标指定位置进行替换,可以带n
shift r:进入替换模式进行替换
shift zz:保存并退出
ctrl z:暂停vim,会出现临时文件(因为强制退出vim,vim保存你当前文件会产生隐藏的临时文件)
(2)插入模式
a:进入后光标退一格
o:进入后新起一行
i:当前光标处插入
(3)底行模式
q:退出
wq:保存并退出
q!:不问直接退出,不保存
set nu:设置行号
set nonu:去掉行号
/:后面跟关键词,搜索关键词
!:后面跟shell命令,不退出vim进行shell命令
vs filename:创建多文件
ctrl ww:在多个文件中光标切换
5、补充知识
(1)如何批量化注释 / 去注释
a、注释
ctrl v 进入视图模式
h j k l 选择要注释的区域
shift i 进入插入模式
//
Esc两次
b、去注释
ctrl v 进入视图模式
h j k l 选择要注释的区域
d 删除
(2)如何在sudoers中添加自己
有时候我们要指令提权进行相关操作,但是直接 sudo 不会成功,因为在对应的 sudoers 配置文件里面没有我,所以我们可以用vim来修改配置文件。
在root账号下,vim/etc/sudoers
在文件100行复制,粘贴后把root改成自己
(3)vim的配置
vim不是简单的可执行程序,他也会读取若干配置文件,如:.vimrc,所以可以再.vimrc中写命令来进行vim的配置。
三、编译器gcc与g++
1、gcc与g++功能和常见用法
gcc与g++都是编译器,gcc用来编译c代码,g++用来编译c++代码。
gcc常见选项
-o:从文件输出到文件,后面可以带名字进行改文件名。
-E:把源文件进行预处理(处理完依然是源文件)
-S:到编译结束后就停止
-c:把文件编译成二进制文件
-static:把源文件进行静态链接(因为默认是动态链接)
宏定义也可以用命令进行 -D选项
2、程序翻译过程
翻译过程 | gcc命令 | 说明 |
预处理 | gcc -E test.c -o test.i | 进行宏替换,去注释,头文件展开,条件编译.. |
编译 | gcc -S test.i -o test.s | 把c变成汇编语言,进行语法检查 |
汇编 | gcc -c test.s -o test.o | 把汇编语言编程二进制目标文件 |
链接 | gcc test.o -o my.exe | 链接形成可执行程序 |
3、链接
(1)链接基础知识
链接就是把程序和库结合的过程。
链接分为静态链接和动态链接
在Linux下,动态链接文件后缀 .so,静态链接后缀 .a
在windows下,动态链接文件后缀 .ddl,静态链接后缀 .lib
ldd filename.exe可以查看动态库
(2)静态链接与动态链接对比
静态链接:在编译的时候,将库中所有方法拷贝到可执行程序中。
动态链接:共享动态库,一旦动态库丢失,所有动态链接库的程序都无法执行。
静态链接优缺点:节省资源,但是库不能丢失。
动态链接优缺点:与库无关,但是要拷贝所有方法,浪费资源。
上图可看到动态链接程序大小大概是静态链接程序大小的一百分之一。
从Linux默认使用动态链接就可以看出推荐我们使用动态链接,但是静态链接也会有使用场景,比如要代码有很强的跨平台性时就需要静态链接。
四、项目自动化构建工具makefile
1、makefile基础知识
(1)一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的 规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。
(2)makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编 译,极大的提高了软件开发的效率。 make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命 令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一 种在工程方面的编译方法。
(3)make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。
2、makefile代码实现与解释
上图是一个makefile文件例子。
第一行:mytest表示目标文件,test.c表示依赖文件列表(当然此时只有一个依赖文件)。第一行就是文件的依赖关系。
第二行:既然有了文件依赖关系,我们就需要知道依赖方法,就是把test.c文件编译成mytest可执行程序。依赖方法可以是多行。
第三行:.PHONY表示之后的方法总是被执行。因为为了保证效率,有些文件如果未更新,某些操作就不会进行,还会出现警告。在.PHONY之后的操作不会对比时间,也就不会出现重复操作出现警告的情况。
第四行:依然表示依赖关系。
第五行:依赖方法。
3、makefile优化
$:表示从文件中读取数据
@:目标文件
^:依赖文件列表
vim也支持定义变量。
上图中bin表示目标文件,src表示依赖文件列表。
在依赖方法前加@在执行make时就不会打印出执行过程。
4、补充知识
(1)makefile是对文件从上往下扫描,但是对于文件关系顺序杂乱的依赖方法,makefile实际上是用栈来存储,所以不怕关系杂乱的情况。
(2)仅有make指令只会生效第一个依赖文件。make + 依赖文件就能执行指定指令。
(3)回车与换行
回车:光标移动到行开始处。\r
换行:光标下移一行。
回车换行:光标移动到下一行的开始。\n
(4)缓冲区
程序结束,\n,缓冲区满了都会导致缓冲区的刷新,而对应到显示器文件的缓冲区刷新就是把缓冲区中的数据显示到显示屏上。
在c语言中 stdin 表示键盘文件,stdout stderr 是显示器文件,所以我们可以用 fflush(file* stream) 函数来实现缓冲区的强制刷新,如强制刷新显示器 fllush(stdout)
缓冲区的作用就是提高运行效率。
五、版本控制器git
1、对于git的理解
git是一个软件,而gitee和github是基于git搭建的一个网站。
2、常见的git命令
git status 查看仓库状态
git add filename 添加文件到git仓库
git commit -m ‘....’ 提交文件到git本地仓库并附上日志
git push 把本地仓库的文件提交到远端(需要输入用户名密码)
git log 查看历史提交信息(倒序)
3、提交文件流程
4、.gitingnore文件
在.gitignore文件中存放的是我们提交文件是需要忽略的文件的后缀名。以免过程中产生的临时文件也传上去。
六、gdb调试
1、debug与release模式
debug一般是程序员开发的模式,特点就是可以调试代码,而release模式是用户的模式,特点是运行快,大小较小。
那么为什么debug能调试呢,就是因为在debug模式下文件会添加调试信息,这也就导致文件大小较大。
上图中的mytest是release模式编译的,mytest-debug是debug模式下编译的。想用debug模式编译只要-g选项就行。
2、常见调试指令
gdb filename 进入调试
l num:(list) num表示行号,表示查看代码。
r:(run) 进行调试
b num:(break) 在num行打断点。
i b:(info) 查看断点信息。
d Num:(delete) 删除指定断点,注意这里的Num表示断点的编号(在i b里面看)
disable Num: 禁用断点
enable Num: 重启断点
n:(next) 逐过程调试
s:(step) 逐语句调试
p 变量名:(print) 查看变量值
display 变量名: 常显示变量名
undisplay 变量名: 取消常显示
c:(continue) 跳到下一个断点
finish: 走完指定函数停下
until num: 跳转到指定行
info local: 查看所有临时变量
set var 变量=...: 修改变量值
bt: 显示调用堆栈