文章目录
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>intmain(){printf("hello Makefile!\n");sleep(3);return0;}//先打印,后休眠 #include<stdio.h>#include<unistd.h>intmain(){printf("hello Makefile!");sleep(3);return0;}//先休眠,后打印
C语言默认是从上到下执行的,现象解释:
printf早就执行完了,只不过信息没有被立马显示出来
C语言是会给我们提供输出缓冲区的,根据特定的刷新策略,来进行刷新
输出缓冲区
:C语言提供的一段内存空间
显示器设备,一般的刷新策略是行刷新,就是碰到/n,就把/n之前的所有字符全部显示出来
立刻刷新,不缓存:fflush
#include<stdio.h>#include<unistd.h>intmain(){printf("hello Makefile!");fflush(stdout);//标准刷新sleep(3);return0;}
进度条代码
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>#defineNUM102intmain(){char bar[NUM];memset(bar,0,sizeof(bar));//旋转光标//"|/-\\"constchar*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");return0;}
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 断点编号:关闭断点
版权归原作者 Hey pear! 所有, 如有侵权,请联系我们删除。