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 文件名 分屏操作
注意:光标在哪个分屏下,底行就是哪个分屏的
分屏在阅读别人的源代码时使用的情况居多
w 写入保存 w!
q 退出 q!
:!cmd 不退出vim执行对应的命令(执行命令行,编译,运行,查看man等)
例如:
:!gcc 文件名 直接编译
:!ls
配置文件的位置在目录 /etc/ 下面,有个名为vimrc的文件,这是系统中公共的vim配置文件,对所有用户都有效。
而在每个用户的主目录下,都可以自己建立私有的配置文件,命名为“.vimrc”。例如,/root目录下,通常已经存在一个.vimrc文件,如果不存在,则创建之。
切换用户成为自己执行 su ,进入自己的主工作目录,执行 cd ~打开自己目录下的.vimrc文件,执行 vim .vimrc
自己进行配置自己需要的
例如:
使用常见插件:
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 可以新建用户
安装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:表明使用静态链接的方式形成可执行程序
make是一个命令
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是如何得知,我的可执行程序是最新的?
根据文件的最新修改时间来的
sleep休眠接口
proc.c
#include
#include
int main()
{
printf("hello Makefile!\n");
sleep(3);
return 0;
}
//先打印,后休眠
#include
#include
int main()
{
printf("hello Makefile!");
sleep(3);
return 0;
}
//先休眠,后打印
C语言默认是从上到下执行的,现象解释:
printf早就执行完了,只不过信息没有被立马显示出来
C语言是会给我们提供输出缓冲区的,根据特定的刷新策略,来进行刷新
输出缓冲区
:C语言提供的一段内存空间
显示器设备,一般的刷新策略是行刷新,就是碰到/n,就把/n之前的所有字符全部显示出来
立刻刷新,不缓存:fflush
#include
#include
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
#include
#include
#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相当于安卓的应用市场
一般原生的Linux系统,内置的下载链接基本都是自己配套的国外的网址
yum其实是用python写的一个小工具
yum源:配置文件
ls /etc/yum.repos.d
下载yum源:
sudo yum install -y epel-release
更新国内yum源:
上网搜
历史:雷纳斯托瓦兹,自己手写了一个版本控制器,git
预备:
git add .
你的文件 添加我们的代码到本地仓库git commit -m "这里必须写提交日志"
提交代码到仓库中git push
提供代码到远端仓库有时候无法提交,会出现提交冲突时就无脑
git pull
.gitignore 不想提交某些后缀的文件同步到远端的git仓库,就可以添加到.gitignore
( 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会记录最近一条命令,如果命令无变化,可以直接回车