linux——环境基础开发工具使用_gcc test file

文章目录

Linux编辑器-vim使用

vi/vim的区别简单点来说,它们都是多模式编辑器,不同的是vim是vi的升级版本,它不仅兼容vi的所有指令,而且还有一些新的特性在里面。
例如语法加亮,可视化操作不仅可以在终端运行,也可以运行于x window、macos、windows。

vim编辑器——只负责写代码

命令

  • 打开:vim 直接输vim
  • 关闭:shift+:q
  • 退出:q
  • 编写代码之后怎么退出:先按esc,再shift+:wq
  • 保存:w
  • ! 表示强制
  • q!强制退出

那么代码写完了,那么vim究竟怎么用呢?

  1. vim刚刚打开的时候,是命令模式(默认打开的模式)
  2. 输入i insert 正常输入代码 编辑/插入模式
    esc 转变为命令模式——此时无法写代码
  3. shift+: 退出——只能再底行模式
    est又可以直接退回到命令模式

在插入模式不可以直接进入底行模式(反之也亦然)

命令模式——常见命令:

  • 将当前光标所在的行复制:yy 将当前光标所在的包括当前以下5行:5yy
  • 粘贴一次:p 1000p粘贴一千次: np
  • 将当前光标所在的行剪切(删除):dd 剪切(删除)n行:ndd
  • 撤销:u
  • 撤销之前u撤销的操作 Ctrl+R

光标定位

  1. 行外操作 上下
    shift+g 光标定位到文件结尾
    gg 光标定位到文件最开始
    n+shift+g 标定位到文件第n行
  2. 行内操作 左右
    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 翻译成 计算机的二进制

  1. 预处理
    去注释
    宏替换
    头文件展开
    条件编译
  2. 编译
    c——>汇编
  3. 汇编
    汇编——>可重定向二进制目标文件
  4. 链接
    链接——>多个.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默认就是一步到位,想要一步一步来也可以:

  1. 预处理
    gcc -E mytest.c -o mytest.i
    -E:从现在开始进行程序的翻译,如果预处理完成就停下来
    mytest.i是生成的预处理文件
    预处理之后还是C语言
  2. 编译
    gcc -S mytest.i -o mytest.s
    -S:从现在开始进行程序的翻译,如果编译完成,就停下来
  3. 汇编
    gcc -c mytest.s -o mytest.o
    -c:从现在开始进行程序的翻译,如果汇编完成,就停下来
    这里的.o文件已经变成二进制,也就是可重定向二进制目标文件

连起来就是ESc iso

  1. 链接
    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:表明使用静态链接的方式形成可执行程序

  1. 你的机器可能没有静态库而导致链接失败
  2. 动态链接必须使用.so动态库文件
  3. 静态链接必须使用.a静态库文件
  4. sudo yum install -y glibc-static 安装C语言静态库
  5. 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值