1、vim基本概念
vim编辑器主要有三种操作模式:命令模式、插入模式和底行模式。
- 命令模式:在该模式下,所有的键盘输入都被视为命令,用于控制光标移动、删除字符、字或行等操作。按i键进入插入模式,按:键进入底行模式。
- 插入模式:在此模式下,所有的键盘输入都会被视为文本输入。按esc键可以切换回命令模式。
- 底行模式:用于文件的保存或退出、替换文本、查找字符串、显示行号等操作。同样,按esc键可以返回命令模式。
vim总共有12种模式,包括6种基本模式和6种附加模式。输入help vim-modes可以查看所有模式。
2、vim操作
(1) 命令模式
进入vim时,默认处于命令模式。以下是一些常用命令:
命令 | 作用 |
---|---|
gg | 光标移动到文章开头 |
G | 光标移动到文章末尾 |
num+G | 光标移动到第num行行首 |
$ | 光标移动到当前行末尾 |
^ | 光标移动到当前行开头 |
w,b | 光标按单词移动,跨行 |
h,j,k,l | 光标左移、下移、上移、右移 |
(num)yy | 复制光标所在行或num行 |
(num)dd | 剪切或删除光标所在行或num行 |
(num)p | 粘贴到光标所在行下方num次 |
u | 撤销上一步操作 |
ctrl+r | 重做上一步撤销的操作 |
~ | 转换光标所在字符的大小写 |
(num)r | 替换光标所在字符或之后的num个字符 |
R | 进入替换模式,类似于第四种模式 |
(num)x | 删除光标所在字符或之后的num个字符 |
(2) 插入模式
进入插入模式后,可以直接编辑文本,输入的字符会显示在文本中。
(3) 底行模式
以下是底行模式的常用命令:
命令 | 作用 |
---|---|
set nu | 显示文件每一行的行号 |
(num) | 直接跳转到第num行 |
/+字符 | 向前查找字符,按n继续查找 |
?+字符 | 向后查找字符,按n继续查找 |
w | 保存文件 |
q | 退出文件 |
q! | 强制退出文件 |
wq | 保存并退出文件 |
wq! | 强制保存并退出文件 |
3、vim配置
未经配置的vim不适合编写代码,因为它原本只是一个文本编辑器。配置vim可以优化编程环境。文本文件建议使用nano编辑,而代码则使用vim。
vim的配置文件是隐藏文件.vimrc。
推荐使用一键配置vim,避免手动配置的麻烦。在Linux下输入以下命令并输入root密码即可完成配置,配置完成后重启shell。
二、编译工具–gcc/g++编译器
1、程序翻译过程
C程序的翻译过程包括预处理、编译、汇编和链接四个阶段。
- 预处理:进行宏替换,生成.i文件。
- 编译:检查代码规范性和语法错误,生成.s文件。
- 汇编:生成机器可识别的代码,生成.o文件。
- 链接:链接库文件生成可执行程序。
从图片中可以看出,test.c经过预处理生成test.i,文件大小增加很多,这是因为宏替换和头文件包含。编译后文件变小,汇编生成二进制编码后文件变大,最后链接库生成可执行文件。
库分为动态库和静态库。静态库在链接时将库中的目标文件与程序自身的目标文件组合,生成独立的可执行文件,但文件较大。动态库则在程序运行时动态链接,文件较小,但依赖外部库文件。
静态链接时使用-Static选项。
可以看出静态链接的文件比动态链接的大100倍。默认的动态链接实际上是混合链接,既有动态部分也有静态部分。
2、动态和静态库注意事项
- 没有静态库无法进行静态链接。
- 没有动态库但有静态库时,默认动态链接指令仍然可以链接静态库。
- 默认的gcc test.c -o test指令是混合链接,加上-static选项则全部静态链接。
3、gcc使用
选项1 | 作用 |
---|---|
-E | 只进行预处理 |
-S | 编译到汇编语言,不进行汇编和链接 |
-c | 编译到目标代码 |
选项2 | 作用 |
---|---|
-o | 指定输出文件 |
1、简介
git是一个开源的分布式版本控制系统,用于管理软件开发过程中的代码版本。git允许开发人员在本地克隆代码仓库,进行开发、提交、推送等操作,并与远程仓库同步。每个开发者都拥有完整的代码仓库副本,包括所有版本历史和元数据,使开发过程更加独立和灵活。
与集中式版本控制系统不同,git没有单一的中心服务器,每个开发者的本地机器上都有一个完整的版本库。开发者可以在本地进行完整的开发流程,包括提交、暂存等操作,而无需依赖网络连接到中心服务器。
git使用“快照”方式存储版本信息,每次提交时为整个项目创建一个快照,记录所有文件的状态。git采用高效的压缩算法和数据结构存储这些快照,减少存储空间占用,并能快速进行版本切换和合并。
git的分支创建和切换非常轻量级,开发者可以轻松创建多个分支,用于不同开发任务,如功能开发、修复bug等。各个分支之间相互独立,开发人员可以在不同分支上并行开发,然后根据需要将分支合并到主分支或其他分支上。
主要用于团队协作开发、代码备份与恢复、开源项目管理。
2、git使用
大家对Github和gitee并不陌生,前者是全球最大的开源代码托管平台,后者是面向国内开发者的代码托管平台。可以从中下载许多开源项目和学习资料,也可以开源项目供其他人查看。由于github访问不稳定,需要借助“技术”才能使用,这里展示Gitee的使用。
创建新仓库时,下方的三个选项可以选择或不选择。如果仓库是单一文件仓库,建议勾选.gitignore,它会将指定后缀名的文件在推送时默认不推送。
readme文件是开源项目的说明书,必不可少。
通过git clone + 远端仓库链接将远程仓库克隆到本地。
创建并编辑文件后,将文件添加到暂存区,然后提交到本地仓库,最后推送到远程仓库,并在备注中说明文件内容。
今日分享到此结束。