Linux开发工具-vim-gcc-gdb指令及使用

这篇具有很好参考价值的文章主要介绍了Linux开发工具-vim-gcc-gdb指令及使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

linux软件包管理器yum(apt)

linux开发工具

linux编辑器-vim使用

linux编译器-gcc/g++使用

linux调试器-gdb使用

linux项目自动化构建工具-make/makefile

linux第一个小程序-进度条

使用github创建项目

使用git命令



我们前面学了关于linux的基本指令和基本权限的一些相关知识,那么我们今天就讲一下关于linux使用的一些工具还有一些小的知识点,后面会看情况补充一些前面讲的浅的或者讲的不太好的知识点。那么现在我们开始吧!

linux软件包管理器yum(apt)

什么是软件包

在Linux下安装软件, 一个通常的办法是下载到程序的源代码, 并进行编译, 得到可执行程序.

但是这样太麻烦了, 于是有些人把一些常用的软件提前编译好, 做成软件包(可以理解成windows上的安 装程序)放在一个服务器上, 通过包管理器可以很方便的获取到这个编译好的软件包, 直接进行安装.

软件包和软件包管理器, 就好比 我们手机里的"App" 和 "应用商店" 这样的关系.大量的应用放在远端服务器里面,然后我们通过软件商店这个端口去访问我们需要的软件,最后下载下来的这样一个过程。

yum(Yellow dog Updater, Modified)是Linux下非常常用的一种包管理器. 主要应用在Fedora, RedHat, Centos等发行版上.

就好比我们的手机,如果我们要下载软件的话,比如说12306,我们是不是就会去手机自带的软件商城或者说应用商店去下载啊?linux就好比我们的手机,yum就好比软件商店,然后我们通过搜索12306(软件名)找到对应的软件下载,我的平台命令是apt(get),大部分平台是yum。

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

我是装了一个tree,树状显示目录的指令,有些服务器是已经装好了的。

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

apt remove tree  卸载软件包

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

这里的话为了我们更好的学习融入,我把服务器的系统重装了一下,之前是ubuntu的版本,现在装了centos7.6,所以接下来的话我会把yum的指令也写一下,方便我们去学习

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

这里我们选y,tree指令就会被卸载

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

这个时候我们再卸载的话,系统就会提示找不到这个指令的包了。

我们在远程下载软件包的时候,要确保网络畅通,这样我们的包才能下载成功

ping www.baidu.com

这个指令可以查看,一般像下面这样就没问题

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

ctrl+c可以退出这个操作,不然我们的这条信息就会一直打印

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

关于 rzsz

这个工具用于 windows 机器和远端的 Linux 机器通过 XShell 传输文件. 安装完毕之后可以通过拖拽的方式将文件上传过去. 

yum install rzsz

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

这个工具的话也不怎么用,因为我们一般很少这样传文件,速度也挺慢的。

查看软件包

通过 yum list 命令可以罗列出当前一共有哪些软件包. 由于包的数目可能非常之多, 这里我们需要使用 grep 命令只 筛选出我们关注的包. 例如:

yum list | grep lrzsz

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

结果如下: lrzsz.x86_64 0.12.20-36.el7   base 

|是管道的符号,就是我们在查看软件包的菜单时,再加上一条我们要筛选的包,这两条指令就会一块执行,最后给到我们需要的信息。

注意事项:

软件包名称: 主版本号.次版本号.源程序发行号-软件包的发行号.主机平台.cpu架构.

"x86_64" 后缀表示64位系统的安装包, "i686" 后缀表示32位系统安装包. 选择包时要和系统匹配. "el7" 表示操作系统发行版的版本.

"el7" 表示的是 centos7/redhat7. "el6" 表示 centos6/redhat6.

最后一列, base 表示的是 "软件源" 的名称, 类似于 "小米应用商店", "华为应用商店" 这样的概念.

如何安装软件

通过 yum, 我们可以通过很简单的一条命令完成 gcc 的安装.

sudo yum install lrzsz

yum 会自动找到都有哪些软件包需要下载, 这时候敲 "y" 确认安装. 出现 "complete" 字样, 说明安装完成. 前面一开始我说的下载也是一样的指令

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

注意事项:

安装软件时由于需要向系统目录中写入内容, 一般需要 sudo 或者切到 root 账户下才能完成.

yum安装软件只能一个装完了再装另一个.

正在yum安装一个软件的过程中, 如果再尝试用yum安装另外 一个软件, yum会报错.

如果 yum 报错, (试一下,可能是apt install),不行就要找度娘了。

卸载的话前面有提到

sudo yum remove lrzsz

这里我就不试了,等下还要装,怪难受的。

linux开发工具

对于Linux开发,以下是一些常用的工具:

  1. VIM(vi improved)是一种强大的文本编辑器和命令行处理器,虽然它主要用于文本编辑,但它也提供了一些基本的编译和调试功能。VIM有多种模式,如正常模式、编辑模式、命令行模式等,这些模式的组合使得它在日常开发工作中非常有用。
  2. GCC(GNU Compiler Collection)是一套用于编译C和C++等语言的编译器。它是开源的,可以在多种操作系统上运行,包括Linux。
  3. GDB(GNU Debugger)是一个功能强大的调试器,可以用来跟踪程序的执行过程,查找错误并进行修复。

  4. Make和Makefile是构建系统的关键组成部分,它们允许开发者定义规则来自动化编译和链接的过程。

  5. Bluefish是一款Web开发的集成开发环境(IDE),它支持HTML、CSS、JavaScript等多种Web技术,并提供了一个直观的用户界面来帮助开发者进行创作和管理网站。3

  6. Anjuta是一个跨平台的C和C++开发环境,它提供了项目管理、应用程序向导、交互式调试器以及一个功能强大的源代码编辑器。

  7. Eclipse CDT(Eclipse C/C++ Development Tools)是基于Eclipse平台的一个C和C++集成开发环境,它包含了代码编辑器、构建工具、调试器等一系列开发所需的功能。

以上只是部分常见的Linux开发工具,实际上,Linux平台上还存在着许多其他类型的开发工具,以满足不同的开发需求。我们下面讲用得比较多的几种即可,贪多嚼不烂嘛。

linux编辑器-vim使用

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

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

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维​ Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

1. vim的基本概念

我们现在说的vim的三种模式(其实有好多模式,我就学这这3种...),分别是命令模式(command mode)、插 入模式(Insert mode)和底行模式(last line mode),各模式的功能区分如下: 

正常/普通/命令模式(Normal mode) 控制屏幕光标的移动,字符、字或行的删除,移动复制某区段及进入Insert mode下,或者到 last line mode

插入模式(Insert mode) 只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。该模式是我们后面用的最频繁 的编辑模式。

末行模式(last line mode) 文件保存或退出,也可以进行文件替换,找字符串,列出行号等操作。 在命令模式下,shift+: 即可进入该模 式。

要查看你的所有模式:打开vim,底行模式直接输入 :help vim-modes

我这里一共有12种模式:six BASIC modes和six ADDITIONAL modes.

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维​ vim的基本操作

进入vim,在系统提示符号输入vim及文件名称后,就进入vim全屏幕编辑画面:

$ vim test.c

不过有一点要特别注意,就是你进入vim之后,是处于[正常模式],你要切换到[插入模式]才能够输入文 字

[正常模式]切换至[插入模式]

输入a

输入i

输入o

[插入模式]切换至[正常模式]

目前处于[插入模式],就只能一直输入文字

如果发现输错了字,想用光标键往回移动,将该字删除,可以先按一下「ESC」键转到[正常模式]再删除文字。当然,也可以直接删除。

[正常模式]切换至[末行模式] 「shift + ;」, 其实就是输入「:」

退出vim及保存文件,在[正常模式]下,按一下「:」冒号键进入「Last line mode」

例如 : w (保存当前文件) 

wq (输入「wq」,存盘并退出vim) :

q! (输入q!,不存盘强制退出vim)

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维​ vim正常模式命令集

插入模式
按「i」切换进入插入模式「insert mode」,按“i”进入插入模式后是从光标当前位置开始输入文件;
按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字;
按「o」进入插入模式后,是插入新的一行,从行首开始输入文字。
从插入模式切换为命令模式
按「ESC」键。
移动光标
vim可以直接用键盘上的光标来上下左右移动,但正规的vim是用小写英文字母「h」、「j」、「k」、「l」,分别控制光标左、下、上、右移一格
按「G」:移动到文章的最后
按「$」:移动到光标所在行的“行尾”
按「^」:移动到光标所在行的“行首”
按「w」:光标跳到下个字的开头
按「e」:光标跳到下个字的字尾
按「b」:光标回到上个字的开头
按「#l」:光标移到该行的第#个位置,如:5l,56l
按[gg]:进入到文本开始
按[shift+g]:进入文本末端
按「ctrl」+「b」:屏幕往“后”移动一页
按「ctrl」+「f」:屏幕往“前”移动一页
按「ctrl」+「u」:屏幕往“后”移动半页
按「ctrl」+「d」:屏幕往“前”移动半页
删除文字
「x」:每按一次,删除光标所在位置的一个字符
「#x」:例如,「6x」表示删除光标所在位置的“后面(包含自己在内)”6个字符
「X」:大写的X,每按一次,删除光标所在位置的“前面”一个字符
「#X」:例如,「20X」表示删除光标所在位置的“前面”20个字符
「dd」:删除光标所在行
「#dd」:从光标所在行开始删除#行
复制
「yw」:将光标所在之处到字尾的字符复制到缓冲区中。
「#yw」:复制#个字到缓冲区
「yy」:复制光标所在行到缓冲区。
「#yy」:例如,「6yy」表示拷贝从光标所在的该行“往下数”6行文字。
「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与“y”有关的复制命令都必须与“p”配合才能完成复制与粘贴功能。
替换
「r」:替换光标所在处的字符。

「R」:替换光标所到之处的字符,直到按下「ESC」键为止。
撤销上一次操作
「u」:如果您误执行一个命令,可以马上按下「u」,回到上一个操作。按多次“u”可以执行多次回
复。
「ctrl + r」: 撤销的恢复
更改
「cw」:更改光标所在处的字到字尾处
「c#w」:例如,「c3w」表示更改3个字
跳至指定的行
「ctrl」+「g」列出光标所在行的行号。
「#G」:例如,「15G」,表示移动光标至文章的第15行行首。

vim末行模式命令集

在使用末行模式之前,请记住先按「ESC」键确定您已经处于正常模式,再按「:」冒号即可进入末行模式。
列出行号
「set nu」: 输入「set nu」后,会在文件中的每一行前面列出行号。
跳到文件中的某一行
「#」:「#」号表示一个数字,在冒号后输入一个数字,再按回车键就会跳到该行了,如输入数字15,
再回车,就会跳到文章的第15行。
查找字符
「/关键字」: 先按「/」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直按
「n」会往后寻找到您要的关键字为止。
「?关键字」:先按「?」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直
按「n」会往前寻找到您要的关键字为止。
问题:/ 和 ?查找有和区别?操作实验一下
保存文件
「w」: 在冒号输入字母「w」就可以将文件保存起来
离开vim
「q」:按「q」就是退出,如果无法离开vim,可以在「q」后跟一个「!」强制离开vim。
「wq」:一般建议离开时,搭配「w」一起使用,这样在退出的时候还可以保存文件。

因为指令这一块的话确实是有点多,我们平时基本不会用到这么多,哪个用的多记一下就可以了。

vim操作总结

三种模式 正常模式 插入模式 底行模式

我们一共有12种总模式,大家有兴趣的话可以自己研究一下 

vim操作 打开,关闭,查看,查询,插入,删除,替换,撤销,复制等等操作。

我们会以上这些常用的基本也算入门了的。

简单vim配置

配置文件的位置 在目录 /etc/ 下面,有个名为vimrc的文件,这是系统中公共的vim配置文件,对所有用户都有效。

而在每个用户的主目录下,都可以自己建立私有的配置文件,命名为:“.vimrc”。

例如,/root目录下, 通常已经存在一个.vimrc文件,如果不存在,则创建之。

切换用户成为自己执行su,进入自己的主工作目录,执行 打开自己目录下的.vimrc文件,

执行vim .vimrc(空格)

常用配置选项

设置语法高亮: syntax on

显示行号: set nu

设置缩进的空格数为4: set shiftwidth=4

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

需要完全配置类似IDE那种的话,建议使用插件,具体的话可以看看其他大佬配置的经验。

要配置好看的vim,原生的配置可能功能不全,可以选择安装插件来完善配置,保证用户是你要配置的用户,接下来:
安装TagList插件,下载taglist_xx.zip ,解压完成,将解压出来的doc的内容放到~/.vim/doc, 将解压出来
的plugin下的内容拷贝到~/.vim/plugin
在~/.vimrc 中添加:
let Tlist_Show_One_File=1
let Tlist_Exit_OnlyWindow=1
let Tlist_Use_Right_Window=1
安装文件浏览器和窗口管理器插件: WinManager
下载winmanager.zip,2.X版本以上的
解压winmanager.zip,将解压出来的doc的内容放到~/.vim/doc, 将解压出来的plugin下的内容拷贝到 ~/.vim/plugin
在~/.vimrc 中添加
let g:winManagerWindowLayout=‘FileExplorer|TagList
nmap wm :WMToggle<cr>
然后重启vim,打开~/XXX.c或~/XXX.cpp, 在normal状态下输入"wm", 你将看到上图的效果。
更具体移步:
 其他手册,请执行vimtutor 命令。

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

这里我就不说配置后的情况了,我自己没有按照他这么配置

想配置的多一点功能的话可以看看下面这篇文章

GitHub - wsdjeg/vim-galore-zh_cn: Vim 从入门到精通

linux编译器-gcc/g++使用

背景知识

1. 预处理(进行宏替换)
 2. 编译(生成汇编)
 3. 汇编(生成机器可识别代码)
4. 连接(生成可执行文件或库文件)

gcc的安装我在开头有写,可以到开头位置看看。
gcc如何完成

格式
gcc [选项] 要编译的文件 [选项] [目标文件]
预处理(进行宏替换)
预处理功能主要包括宏定义,文件包含,条件编译,去注释等。
预处理指令是以#号开头的代码行。
实例:
gcc –E hello.c –o hello.i
选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。
选项“-o”是指目标文件,“.i”文件为已经过预处理的C原始程序。
编译(生成汇编)
在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查
无误后,gcc 把代码翻译成汇编语言。
用户可以使用“-S”选项来进行查看,该选项只进行编译而不进行汇编,生成汇编代码。
实例:
gcc –S hello.i –o hello.s
汇编(生成机器可识别代码)
汇编阶段是把编译阶段生成的“.s”文件转成目标文件
读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了
实例:
gcc –c hello.s –o hello.o
连接(生成可执行文件或库文件)
在成功编译之后,就进入了链接阶段。
实例:
gcc hello.o –o hello
在这里涉及到一个重要的概念:函数库
我们的C程序中,并没有定义“printf”的函数实现,且在预编译中包含的“stdio.h”中也只有该函数的声明,而没有定义函数的实现,那么,是在哪里实“printf”函数的呢?
最后的答案是:系统把这些函数实现都被做到名为 libc.so.6 的库文件中去了,在没有特别指定时,gcc 会到
系统默认的搜索路径“/usr/lib”下进行查找,也就是链接到 libc.so.6 库函数中去,这样就能实现函
数“printf”了,而这也就是链接的作用

函数库一般分为静态库和动态库两种


静态库是指编译链接时,把库文件的代码全部加入到可执行文件中,因此生成的文件比较大,但在运行时也就不再需要库文件了。其后缀名一般为“.a”
动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中,而是在程序执行时由运行时
链接文件加载库,这样可以节省系统的开销。动态库一般后缀名为“.so”,如前面所述的 libc.so.6 就是动态
库。gcc 在编译时默认使用动态库。完成了链接之后,gcc 就可以生成可执行文件,如下所示。
gcc
hello.o –o hello
 gcc默认生成的二进制程序,是动态链接的,这点可以通过file 命令验证。

动态库可以理解为我们以前去的网吧,网吧是固定的,我们每次使用的机子是不固定的,我们的需求也是不固定的,就是我们去的时间。

静态库可以理解为我们自己买的电脑,我们的目标是固定的,这个机子是我们自己使用,不需要网络(网吧需要网费,我们的本子不用)


gcc选项

-E  只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面
-S  编译到汇编语言不进行汇编和链接
-c  编译到目标代码
-o  文件输出到 文件
-static 此选项对生成的文件采用静态链接
-g 生成调试信息。GNU 调试器可利用该信息。
-shared 此选项将尽量使用动态库,所以生成文件比较小,但是需要系统由动态库.
-O0
-O1
-O2
-O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高
-w  不生成任何警告信息。
-Wall 生成所有警告信息

gcc选项记忆 esc,iso例子 

linux调试器-gdb使用

背景
程序的发布方式有两种,debug模式和release模式
Linux gcc/g++出来的二进制程序,默认是release模式
要使用gdb调试,必须在源代码生成二进制程序的时候, 加上-g选项

gdb就直接输入gdb就会进入gdb模式了。
开始使用

gdb binFile 退出:ctrl + d 或 quit
调试命令:
list/l  行号:显示binFile源代码,接着上次的位置往下列,每次列10行。
list/l 函数名:列出某个函数的源代码。
r或run:运行程序。
n 或 next:单条执行。
s或step:进入函数调用
break(b) 行号:在某一行设置断点
break 函数名:在某个函数开头设置断点
info break :查看断点信息。
finish:执行到当前函数返回,然后挺下来等待命令
print(p):打印表达式的值,通过表达式可以修改变量的值或者调用函数
p 变量:打印变量值。
set var:修改变量的值
continue(或c):从当前位置开始连续而非单步执行程序
run(或r):从开始连续而非单步执行程序
delete breakpoints:删除所有断点
delete breakpoints n:删除序号为n的断点
disable breakpoints:禁用断点
enable breakpoints:启用断点
info(或i) breakpoints:参看当前设置了哪些断点
display 变量名:跟踪查看一个变量,每次停下来都显示它的值
undisplay:取消对先前设置的那些变量的跟踪
until X行号:跳至X行
breaktrace(或bt):查看各级函数调用及参数
info(i) locals:查看当前栈帧局部变量的值
quit:退出gdb

linux项目自动化构建工具-make/makefile

背景

会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力
一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的
规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂
的功能操作
makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编
译,极大的提高了软件开发的效率。
make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命
令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一
种在工程方面的编译方法。
make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。

 如果我们要写一个hello.c

#include<stdio.h>

int main()

{

printf("hello Makefile!\n");

return 0;

}

  Makefile文件  
 hello:hello.o
gcc hello.o -o hello
hello.o:hello.s
gcc -c hello.s -o hello.o
hello.s:hello.i
gcc -S hello.i -o hello.s
hello.i:hello.c
gcc -E hello.c -o hello.i
 .PHONY:clean
 clean: rm -f hello.i hello.s hello.o hello

依赖关系
上面的文件
hello ,它依赖hell.o
 hello.o , 它依赖hello.s
hello.s , 它依赖hello.i
 hello.i , 它依赖hello.c 

依赖方法   gcc hello.* -option hello.* ,就是与之对应的依赖关系

原理

make是如何工作的,在默认的方式下,也就是我们只输入make命令。那么,
1. make会在当前目录下找名字叫“Makefile”或“makefile”的文件。
2. 如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到“hello”这个文件,并把这个文件作为最终的目标文件。
3. 如果hello文件不存在,或是hello所依赖的后面的hello.o文件的文件修改时间要比hello这个文件新(可以用touch测试),那么,他就会执行后面所定义的命令来生成hello这个文件。
4. 如果hello所依赖的hello.o文件不存在,那么make会在当前文件中找目标为hello.o文件的依赖性,如果找到则再根据那一个规则生成hello.o文件。(这有点像一个堆栈的过程)
5. 当然,你的C文件和H文件是存在的啦,于是make会生成 hello.o 文件,然后再用 hello.o 文件声明make的终极任务,也就是执行文件hello了。
6. 这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
7. 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make根本不理。
8. make只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,那么对不起,我就不工作啦。

项目清理
工程是需要被清理的
像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行。即命令——“make clean”,以此来清除所有的目标文件,以便重编译。
但是一般我们这种clean的目标文件,我们将它设置为伪目标,用.PHONY修饰,伪目标的特性是,总是被执行的。
可以将我们的hello目标文件声明成伪目标,测试一下。

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

运行makefile 提示:makefile 3 missing separator.stop:

检查了一番发现,有几个原因会引起这样的结果:

第一:makefile的命令行,开头必须用tab键,目前没有发现tabstop的设定值的不同,会引起error。例如:

                        set tabstop=3(默认)  OR   set tabstop=4等,均可以。

第二:编码方式引起的原因。这个原因不多见,不容易发现。查看/etc/vimrc文件以及~/.vimrc,查看是否有set fileencodings的选项,是否设定了utf-8。没有的话加上。

linux第一个小程序-进度条

\r&&\n 回车 换行 老式打字机

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

大家思考一下,这个程序运行会有什么效果

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

我们可以看到,程序运行后我们的命令窗口会停顿一下,然后就恢复正常

那如果我们把换行符删了呢?这还会一样吗?

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

 我们可以看到是先停顿,然后在打印,最后没有换行,命令行就会在打印数据后显示Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

那如果是这样呢?

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维 可以看到,我们是先将打印的数据显示出来,然后再光标停顿一下,接着显示命令行的Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

这个函数是什么呢?

`fflush(stdout)` 的用法是在 `printf()` 或其他用于写入标准输出的函数之后调用。它的主要作用是立即刷新(或清空)输出缓冲区,确保之前输出的数据能够被及时地发送到终端或者文件等输出目的地。 

在某些情况下,不使用 `fflush(stdout)` 时,系统可能会按照自己的节奏(比如定时器触发或者其他事件)来刷新输出缓冲区,这可能导致输出的顺序不一致。因此,为了避免这种情况,应该在每次输出完成后使用 `fflush(stdout)` 来保证数据的即时输出。

那么缓冲区是什么呢?

缓冲区(Buffer)是一个存储区域,通常位于内存空间中,用于存储输入或输出数据。它的大小是固定的,这种设计允许数据在缓冲区中暂时存储,以便在需要时可以快速检索,从而提高数据处理的效率。根据其在系统中的作用,缓冲区可以分为不同类型,如输入缓冲区和输出缓冲区。输入缓冲区通常位于CPU和输入设备之间,而输出缓冲区则位于CPU和输出设备之间。缓冲区的存在有助于减少物理读写次数,实现CPU与低速输入输出设备之间的隔离,使CPU能够高效执行其他任务,同时减少内存碎片,提高内存使用效率。

也可以称作缓存,就是说我们输入的数据和要输出的数据并不是立刻到内存中,而是根据输入输出设备的不同而进入了缓冲区,当达到一定条件后(缓冲区满或者遇到换行符时),数据才会输出,根据缓冲区的不同,缓冲区的刷新也分为几种

  1. 无缓冲区(立刻释放信息,被计算机读取)

  2. 行缓冲区 (遇到 \n 就会刷新释放缓冲区)

  3. 全缓冲区(缓冲区满了的时候,才会刷新缓冲区,file文件刷新 )

  4. 程序退出,自动刷新

所以当我们使用fflush刷新的时候,数据就会立即显示在屏幕上。

说回进度条

我们平时见到的进度条是不是都是有%号刷新的,然后还有一个条子从左到右依次递进。

嗯,大概是这个样子

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

我们这次就写个纯文本的进度条,有兴趣的可以接下来搞一下颜色什么的

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

不要忘记fflush刷新,养成好习惯

-100是预留100个位置给进度条递进

-3是给100%预留的

我们要显示%就输入%%这个格式

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

最后的效果大概就是这样

使用github创建项目

1.注册账号

GitHub: Let’s build from here · GitHub

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维 参考着官网提示即可. 需要进行邮箱校验

2.创建项目

登陆成功后, 进入个人主页, 点击左下方的 New repository 按钮新建项目

我已经建过了,有点不一样

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

然后跳转到的新页面中输入项目名称(注意, 名称不能重复, 系统会自动校验. 校验过程可能会花费几秒钟). 校验 完毕后, 点击下方的 Create repository 按钮确认创建 

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

3.下载项目到本地

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维 创建好一个放置代码的目录.

git clone [hub]

这里的 url 就是刚刚建立好的 项目 的链接

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

我个人推荐用gitee,毕竟在giehub部署到云服务器,有点麻烦

使用git命令行

安装git

yum install git

这个安装就好了,挺快的

三板斧:add

将代码放到刚才下载好的目录中Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

git add like.c

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

这两条命令是配置邮箱和用户名的,这样才能将改动提交到我们的本地仓库

git config --global user.email "you@example.com"
git config --global user.name "Your Name"

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

每次准备提交前,先用 git status 看下,是不是都已暂存起来了

然后再运行提交命令git commit .

这种方式会启动文本编辑器以便输入本次提交的说明。(默认会启用 shell 的环境变量 $EDITOR 所指定的软件,一般都是 vim 或 emacs。当然也可以按照第一章介绍的方式,使用 git config --global core.editor 命令设定你喜欢的编辑软件。)

编辑器会显示类似下面的文本信息:

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

可以看到,默认的提交消息包含最后一次运行 git status 的输出,放在注释行里,另外开头还有一空行,供你输入提交说明。你完全可以去掉这些注释行,不过留着也没关系,多少能帮你回想起这次更新的内容有哪些。(如果觉得这还不够,可以用 -v 选项将修改差异的每一行都包含到注释中来。)退出编辑器时,Git 会丢掉注释行,将说明内容和本次更新提交到仓库。

如果要输入解释的话就需要:

1.按键盘字母 i 进入insert模式

2.修改最上面那行黄色合并信息,可以不修改

3.按键盘左上角"Esc"

4.输入":wq",注意是冒号+wq,按回车键即可

也可以使用 -m 参数后跟提交说明的方式,在一行命令中提交更新。即:git commit -m "这里是信息",添加就不会出现提示了

将需要用 git 管理的文件告知 git

提交到远程仓库 git push

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

Everything up-to-date

这个信息是说我们本次没有文件更新,可是我们刚刚已经添加like.c到本地,为什么会没有呢?

我们在每次push之前,都要提交对应的更新信息,就是本次提交上传的一段话,比如说第一次更新的数据

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

 这样就表示上传成功了,我们也可以到仓库上是否已经上传

Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维

ok,这个就可以了。

本次笔记就记到这里,有不懂的或者写的不好的欢迎私信,阿里嘎多。


Linux开发工具-vim-gcc-gdb指令及使用,Linux,linux,vim,运维文章来源地址https://www.toymoban.com/news/detail-838224.html

到了这里,关于Linux开发工具-vim-gcc-gdb指令及使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [linux初阶][vim-gcc-gdb] OneCharter: vim编辑器

    目录 一.vim编辑器基础 ①.vim的语法 ②vim的三种模式 ③三种模式的基本切换  ④各个模式下的一些操作  二.配置vim环境  ①手动配置(不推荐)  ②自动配置(推荐) vim是vi的升级版,包含了更加丰富的功能. vim [文件名] 命令模式 插入模式   底行模式  如图: 命令模式: shift + 4: 光

    2024年04月17日
    浏览(35)
  • Linux 开发工具vim、gcc/g++、makefile

    目录 Linux编辑器-vim 1. 基本概念 2. 基本操作 3. 正常模式命令集 4. 末行模式命令集 5. 其他操作 6. 简单vim配置 Linux编译器-gcc/g++ 1、基本概念  2、程序翻译的过程 3. gcc如何完成程序翻译 4、动静态库  Linux项目自动化构建工具-make/Makefile 1、背景 2、创建makefile 3、原理 5、项目清

    2024年03月11日
    浏览(56)
  • Linux开发工具:yum、vim、gcc/g++、makefile

    在 Linux 下安装软件一共有三种方式: 源代码安装 有很多开源软件的源代码会被作者放在Github/Gitee 等网站上, 可以将这些源代码下载在本地. 通过直接在本地将这些源代码进行编译链接生成可执行程序 . 在嵌入式编程中, 经常用到交叉编译来处理不同平台的适配性. rpm包直接安装

    2024年01月19日
    浏览(35)
  • Linux:基础开发工具之yum,vim,gcc的使用

    本篇主要总结的是Linux下开发工具 yum vim gcc/g++ 什么是yum? 不管是在手机移动端还是 pc 端,不管是什么操作系统,当用户想要下载一些内容或者工具的时候,都需要到一个特定的位置进行下载,例如在手机上,要下载一些应用的时候就可以去对应的应用商店下载 而在Linux系统

    2024年02月08日
    浏览(35)
  • Linux基础环境开发工具的使用(yum,vim,gcc,g++)

    首先先说明一点: Centos系统适用于yum 而Ubanto适用于apt-get 在Linux中我们也要进行工具/程序/指令的安装,检查和卸载, 而我们安装软件的方式: 1.源代码安装-需要进行交叉编译的工作 一般那些很强的程序员中的大佬才能拿捏 2.rpm包直接安装,也很麻烦 3.yum直接安装 这就需要用到y

    2024年02月06日
    浏览(33)
  • 【Linux】Linux工具篇(yum、vim、gcc/g++、gdb、Makefile、git)

    🚀 作者简介:一名在后端领域学习,并渴望能够学有所成的追梦人。 🚁 个人主页:不 良 🔥 系列专栏:🛹Linux   🛸C++ 📕 学习格言:博观而约取,厚积而薄发 🌹 欢迎进来的小伙伴,如果小伙伴们在学习的过程中,发现有需要纠正的地方,烦请指正,希望能够与诸君一

    2024年02月12日
    浏览(36)
  • Linux——环境开发基础(vim、gcc、yum、git、gdb)

    目录 1.Linux编辑器——vim使用  2.Linux编译器——gcc/g++ 3.Linux项目自动化构建工具——make/Makefile 4.Linux软件包管理器——yum 5.Linux调试器——gdb 前言:因为篇幅原因,本文着重列出命令,小伙伴下去自己尝试,只有多使用才能真的记住!  vim是一款多模式的编辑器 ——命令模式

    2024年02月17日
    浏览(35)
  • Linux中的工具:yum,vim,gcc/g++,make/makefile,gdb

    目录 1、yum 1.1 查看软件包:  1.2 安装软件包 1.3 卸载软件 2、vim 2.1 vim的三种模式 2.2 vim的基本操作 2.3. vim正常模式命令集 2.3.1 插入模式 2.3.2 移动光标 2.3.3 删除文字 2.3.4 复制 2.3.5 替换 2.3.6撤销上一次操作 2.3.7 更改 2.3.8 跳至指定的行 2.4. vim末行模式命令集 3、gcc/g++ 3.1 预处理

    2024年02月10日
    浏览(39)
  • Linux基础工具的使用(yum,vim,gcc,g++,gdb,make/makefile)【详解】

    1.在Linux下安装软件, 一个通常的办法是下载到程序的源代码, 并进行编译, 得到可执行程序。 2.但是这样太麻烦了, 于是有些人把一些常用的软件提前编译好, 做成软件包(可以理解成windows上的安装程序)放在一个服务器上, 通过包管理器可以很方便的获取到这个编译好的软件包

    2024年01月17日
    浏览(39)
  • 【Linux】vim(附配置sudo)、yum、gcc、g++、gdb、make/Makefile工具汇总

    (一)历史沉淀 我们在安装一个软件之前,需要先下载对应的软件包,但是这个软件包并不存在于我们本地的计算机磁盘,而是存在于远端服务器上;那么计算机如何知道该软件存在于具体的哪一台服务器上呢? 对于电脑来说,我们一般通过搜索对应软件的官网来得到相应

    2024年02月13日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包