文章目录
- Linux编辑器-vim使用
- Linux编译器-gcc/g++使用
- Linux项目自动化构建工具-make/Makefile
- Linux第一个小程序-进度条
- yum
- git
- Linux调试器-gdb使用
Linux编辑器-vim使用
vi/vim的区别简单点来说,它们都是多模式编辑器,不同的是vim是vi的升级版本,它不仅兼容vi的所有指令,而且还有一些新的特性在里面。
例如语法加亮,可视化操作不仅可以在终端运行,也可以运行于x window、macos、windows。
vim编辑器——只负责写代码
命令
- 打开:vim 直接输vim
- 关闭:shift+:q
- 退出:q
- 编写代码之后怎么退出:先按esc,再shift+:wq
- 保存:w
- ! 表示强制
- q!强制退出
那么代码写完了,那么vim究竟怎么用呢?
- vim刚刚打开的时候,是命令模式(默认打开的模式)
- 输入i insert 正常输入代码 编辑/插入模式
esc 转变为命令模式——此时无法写代码 - shift+: 退出——只能再底行模式
est又可以直接退回到命令模式
在插入模式不可以直接进入底行模式(反之也亦然)
命令模式——常见命令:
- 将当前光标所在的行复制:yy 将当前光标所在的包括当前以下5行:5yy
- 粘贴一次:p 1000p粘贴一千次: np
- 将当前光标所在的行剪切(删除):dd 剪切(删除)n行:ndd
- 撤销:u
- 撤销之前u撤销的操作 Ctrl+R
光标定位
:
- 行外操作
上下
shift+g 光标定位到文件结尾
gg 光标定位到文件最开始
n+shift+g 标定位到文件第n行- 行内操作
左右
shift 6(^) 将光标定位到当前行的最开始
shift 4(¥)将光标定位到当前行的结尾
w,b 以单词为单位进行光标的前后移动 nw,nb
h j k l 左 下 上 右 jump king
- 大小写切换 shift+~
- 行替换输入 shitf+r 进入替换模式 replase
- r 替换光标所在的字符 nr
- 删除光标所在的字符,包括之前或者之后 x shift + x
底行模式常见命令:
:set no/nonu
打开行号,或者取消行号- vs 文件名 分屏操作
注意:光标在哪个分屏下,底行就是哪个分屏的
- ctrl+按两下w 光标就切换到另外的分屏上
- 退出分屏也是 shfit + : wq
分屏在阅读别人的源代码时使用的情况居多
- w 写入保存 w!
- q 退出 q!
- :!cmd 不退出vim执行对应的命令(执行命令行,编译,运行,查看man等)
例如: - :!gcc 文件名 直接编译
- :!ls
简单vim配置
配置文件的位置在目录 /etc/ 下面,有个名为vimrc的文件,这是系统中公共的vim配置文件,对所有用户都有效。
而在每个用户的主目录下,都可以自己建立私有的配置文件,命名为“.vimrc”。例如,/root目录下,通常已经存在一个.vimrc文件,如果不存在,则创建之。
切换用户成为自己执行 su ,进入自己的主工作目录,执行 cd ~打开自己目录下的.vimrc文件,执行 vim .vimrc
自己进行配置自己需要的
例如:
- 设置语法高亮: syntax on
- 显示行号: set nu
- 设置缩进的空格数为4: set shiftwidth=4
使用常见插件:
https://gitee.com/HGtz2222/VimForCpp?_from=gitee_search
安装方法
在 shell 中执行指令(想在哪个用户下让vim配置生效, 就在哪个用户下执行这个指令. 强烈 “不推荐” 直接在 root下执行):curl -sLf https://gitee.com/HGtz2222/VimForCpp/raw/master/install.sh -o ./install.sh && bash ./install.sh
需要按照提示输入 root 密码. 您的 root 密码不会被上传, 请放心输入.
卸载方法
在安装了 VimForCpp 的用户下执行:
bash ~/.VimForCpp/uninstall.sh
普通用户执行 sudo ls -al 可以新建用户
Linux编译器-gcc/g++使用
背景知识
安装g++
sudo yum install -y gcc-c++
gcc 文件名 只是编译
运行是 ./a.out
程序翻译的过程: 文本的c 翻译成 计算机的二进制
预处理
去注释
宏替换
头文件展开
条件编译编译
c——>汇编汇编
汇编——>可重定向二进制目标文件链接
链接——>多个.o .obj——>合并成一个可执行的.exe
如何完成
gcc只能编译C语言,但是g++可以编译c也可以编译C++
查版本:gcc -v g++ -v
gcc mytest.c -o mytest
编译mytest.c,mytest就是形成的可执行程序
./mytest 就可以直接运行
第二种写法:gcc -o mytest mytest.c
总之-o要和可执行程序连在一起
gcc默认就是一步到位,想要一步一步来也可以:
- 预处理
gcc -E mytest.c -o mytest.i
-E:从现在开始进行程序的翻译,如果预处理完成就停下来
mytest.i是生成的预处理文件
预处理之后还是C语言 - 编译
gcc -S mytest.i -o mytest.s
-S:从现在开始进行程序的翻译,如果编译完成,就停下来 - 汇编
gcc -c mytest.s -o mytest.o
-c:从现在开始进行程序的翻译,如果汇编完成,就停下来
这里的.o文件已经变成二进制,也就是可重定向二进制目标文件
连起来就是ESc iso
- 链接
gcc mytest.o -o mytest
Makefile
mytest:test.o main.o
gcc -o mytest test.o main.o
test.o:test.c
gcc -c test.c -o test.o
main.o:main.c
gcc -c main.c -o main.o
.PHONY:clean
clean:
rm -f \*.o mytest
动静态库
ldd mytest
file mytest
一般链接的过程,有两种方式:
- 动态链接——需要动态库
- 静态链接——需要静态库
libc.-2.17.so -l
库提供C语言的方法实现
ls /usr/include/stdio.h
C语言头文件,提供C语言的方法列表,方法的声明
写的代码包含头文件,链接库文件最终形成exe文件
两个操作系统的区别:
linux: .so(动态库) .a(静态库)
Windows: .dll (动态库) .lib(静态库)
c程序是脱离不开c库文件的
- 动态链接:将库中我要的方法地址,填入我的可执行程序中,建立关联——
节省资源
非常依赖于库文件 - 静态链接:将库中方法的实现,真的拷贝到我们可执行程序中——
占用资源
gcc、g++默认形成的可执行程序是动态链接的
静态链接
gcc test.c -o mytest-s -static
-static:表明使用静态链接的方式形成可执行程序
- 你的机器可能没有静态库而导致链接失败
- 动态链接必须使用.so动态库文件
- 静态链接必须使用.a静态库文件
- sudo yum install -y glibc-static 安装C语言静态库
- sudo yum install -y libstdc+±static 安装c++静态库
Linux项目自动化构建工具-make/Makefile
make是一个命令
makefile是一个文件
维护项目结构
自动化的构建项目
- 创建:touch Makefile
- 编写: vim Makefile
- 依赖关系
- 依赖方法
mytest:test.c//依赖关系 放在前面的才是make的目标
gcc test.c -o mytest//依赖方法
.PHONY:clean//伪目标
clean://依赖关系
re -f mytest//依赖方法
想编译text.c,直接make
清理就直接 make clean
Makefile
make是从上到下扫描
.PHONY
伪目标:总是被执行的——总是会根据依赖关系执行依赖方法
习惯:给clean设置.PHONY:
那么Makefile是如何得知,我的可执行程序是最新的?
根据文件的最新修改时间来的
- stat 文件名 查看一个文件最重要的三个时间
- Access 文件最近被访问的时间
- Modify 修改时间 内容的改变
- Change 属性的变化
- 文件 = 内容+属性
Linux第一个小程序-进度条
行缓冲区概念
sleep休眠接口
proc.c
#include <stdio.h>
#include<unistd.h>
int main()
{
printf("hello Makefile!\n");
sleep(3);
return 0;
}
//先打印,后休眠
#include <stdio.h>
#include<unistd.h>
int main()
{
printf("hello Makefile!");
sleep(3);
return 0;
}
//先休眠,后打印
C语言默认是从上到下执行的,现象解释:
printf早就执行完了,只不过信息没有被立马显示出来
C语言是会给我们提供输出缓冲区的,根据特定的刷新策略,来进行刷新
输出缓冲区
:C语言提供的一段内存空间
显示器设备,一般的刷新策略是行刷新,就是碰到/n,就把/n之前的所有字符全部显示出来
立刻刷新,不缓存:fflush