文章目录
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
#include <stdio.h>
#include<unistd.h>
int main()
{
printf("hello Makefile!");
fflush(stdout);//标准刷新
sleep(3);
return 0;
}
进度条代码
Makefile
proc:proc.c
gcc -o proc proc.c
.PHONY:clean
clean:
rm -f proc
proc.c
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#define NUM 102
int main()
{
char bar[NUM];
memset(bar, 0 ,sizeof(bar));
//旋转光标
//"|/-\\"
const char *lable="|/\\"; //4符号
int cnt = 0;
while(cnt <= 100)
{
printf("[%-100s][%d%%] %c\r", bar, cnt, lable[cnt%4]);
bar[cnt++] = '#';
fflush(stdout);
usleep(30000);
}
printf("\n");
return 0;
}
yum
背景
- 搜索、下载、安装
- 解决依赖关系
yum相当于安卓的应用市场
一般原生的Linux系统,内置的下载链接基本都是自己配套的国外的网址
- 软件发布平台:很多国外的
- 镜像–>国内官方软件平台
- 非官方,预备平台,扩展平台
yum的操作
yum其实是用python写的一个小工具
yum源:配置文件
ls /etc/yum.repos.d
下载yum源:
sudo yum install -y epel-release
更新国内yum源:
上网搜
yum三板斧
- yum list 罗列出所有可下载的软件 yum list | grap sl
- yum install 安装软件 -y 默认确定 sudo yum install -y
- yum remove 移除软件
git
版本控制
历史:雷纳斯托瓦兹,自己手写了一个版本控制器,git
git操作,三板斧
预备:
- git clone 你的代码仓库的链接
git add .
你的文件 添加我们的代码到本地仓库git commit -m "这里必须写提交日志"
提交代码到仓库中git push
提供代码到远端仓库- git rm 可以删除
有时候无法提交,会出现提交冲突时就无脑
git pull
.gitignore 不想提交某些后缀的文件同步到远端的git仓库,就可以添加到.gitignore
Linux调试器-gdb使用
背景认识:
( no debuggging symbols found)
gcc && g++ 默认形成的可执行程序是release的,所以是无法直接被调试的
gcc mytest.c -o mytest-debug -g
开始使用
准备工作
首先要有一个可编译的文件
注意:
Centos linux gdb command not found 错误,可能是安装的时候选择了最小安装,安装一下就可以了。
输入命令: yum -y install gdb
gdb会记录最近一条命令,如果命令无变化,可以直接回车
命令:
- 进入:gdb 文件名
- 退出: ctrl + d 或 quit
- 调试命令: r:开始调试,如果没有设置断点,就直接运行结束
- b 行号:给特定的行号设置断点
- info b: 查看断点(包含断点编号)
- d 断点编号:删除断点 n:逐过程,相当于Windows里面的f10
- p 变量名:打印变量内容
- s:逐语句,f11
- bt:查看当前调用非堆栈
- finish:将当前函数跑完就停下来
- display 变量名:跟踪查看一个变量,每次停下来都显示它的值
- display :设置长显示
- undisplay:取消长显示
- until 行数:跳转到指定行,不建议
- c:运行至下一个断点处停下来
- list/l 行号:显示binFile源代码,接着上次的位置往下列,每次列10
- disable 断点编号:打开断点
- enanble 断点编号:关闭断点