【linux】环境基础|开发工具|gcc|yum|vim|gdb|make|git

 

目录

​编辑

Linux 软件包管理器 yum

软件包:

操作:

拓展:lrzsz简介

Linux开发工具 

Linux编辑器-vim使用

vim 的基本概念

命令模式

插入模式 

底行模式

vim 命令模式的操作指令 

vim 底行模式的操作命令

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

功能

格式

编译过程

 gcc 常见选项:

 Linux调试器-gdb使用

背景

gdb 的使用

 项目自动化构建工具 - make/Makefile (地球人都在用)

准备工作、写法和用法

编写makefile文件

 .PHONY 的作用

 简化 makefile 文件

多文件项目,有 file.h file.c main.c 三个文件

make 是如何工作的

 clean 项目清理

分布式版本控制软件 - git 


Linux 软件包管理器 yum

软件包:

在linux下安装软件,通常办法是下载程序源代码,并进行编译,最后得到可执行程序;但是这样及其麻烦,于是有人将一些常用的软件编译好,做成软件包;类似“app商店”

操作:

yum list :查看当前一共有哪些软件包

例: 

yum list | grep sl

查看当前软件包中筛选出包含sl的软件包;

我们选取其中一个;

sl.x86_64      5.02-1.el7      @epel

 软件包名称:  主版本号.次版本号.源程序发行号-软件包的发行号.主机平台.cpu架构.
“x86_64” 后缀表示64位系统的安装包, “i686” 后缀表示32位系统安装包. 选择包时要和系统匹配.
“el7” 表示操作系统发行版的版本. “el7” 表示的是 centos7/redhat7.

 “el6” 表示 centos6/redhat6.
epel 表示的是 “软件源” 的名称, 类似于 “小米应用商店”, “华为应用商店” 这样的概念.

拓展:lrzsz简介

rz,sz Linux/Unix 同 Windows 进行 ZModem 文件传输的命令行工具。

rz 可以很方便的从客户端传文件到服务器,sz 也可以很方便的从服务器传文件到客户端,就算中间隔着跳板机也不影响。

在 SecureCRT 下的传输协议有 ASCII、Xmodem、Ymodem、Zmodem 4种:

ASCII:这是最快的传输协议,但只能传送文本文件

Xmodem:这种古老的传输协议速度较慢,但由于使用了CRC错误侦测方法,传输的准确率可高达99.6%

Ymodem:这是Xmodem的改良版,使用了1024位区段传送,速度比Xmodem要快。Zmodem:Zmodem采用了串流式(streaming)传输方式,传输速度较快,而且还具有自动改变区段大小和断点续传、快速错误侦测等功能,是目前最流行的文件传输协议

Linux开发工具 

Linux编辑器-vim使用

vi/vim都是多模式编辑器,vim是vi的升级版本,不仅兼容vi的所有指令,而且还有一些新的特性在里面

vim 的基本概念

vim 是编辑器,用于编辑文本,编写代码的工具。因为 vim 的操作是在命令行中,不支持鼠标,因此光标的移动,文本内容的操作都需要命令来完成

这里主要介绍vim最常用的三种模式:命令模式、插入模式、底行模式。

命令模式

 控制屏幕光标的移动,字符、字或行的删除,移动复制某区段或者模式切换

插入模式 

文本数据的写入,模式切换;在命令模式下按 i 进入该模式;按「ESC」键可回到命令行模式

底行模式

文件保存或退出,也可以进行文件替换,找字符串,列出行号等操作在命令模式下,shift + : 即可进入该模式;按「ESC」键可回到命令行模式

 注:底行模式和插入不可转换;

 进入 vim 的方法

vim + 文件名

退出 vim 的方法 (在底行模式):

w (保存当前文件)

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

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

vim 命令模式的操作指令 

vim可以直接用键盘上的光标来上下左右移动,但正规的vim是用小写英文字母**「h」、「j」、「k」、「l」,分别控制光标左、下、上、右移一格**
[gg]:进入到文本开头
「G」「shift + g」「 n + shift + g」:移动到文本末端 或 向下移动n位
「shift + ^」:移动到光标所在行的“行首”
「 shift + $ 」:移动到光标所在行的“行尾”
「w」:光标跳到下个字的开头
「b」:光标回到上个字的开头

按  [ u ] :  撤销上次指令

「x」: 每按一次,删除光标所在位置的一个字符

「n + x」: 例如,「6x」表示删除光标所在位置的“后面(包含自己在内)”6个字符;

「n + dd」: 从光标所在行开始删除 n 行

「dd + p」「n + dd + p」: 剪切某行 或 剪切n行

「p」: 将缓冲区内的字符粘贴到光标所在位置。注意:所有与“y”有关的复制命令都必须与“p”配合才能完成复制与粘贴功能。

「yy」: 复制光标所在行 到缓冲区。

「n + yy」: 例如,「6yy」表示拷贝从光标所在的该行“往下数”6行文字。

vim 底行模式的操作命令

「set nu」: 输入「set nu」后,会在文件中的每一行前面列出行号。

「set nonu」: 取消行号。

「/ + 关键字」: 先按「/」键,再输入想寻找的字符,如果第一次找的关键字不是您想要的,可以一直按「n」会往后寻找到您要的关键字为止。

「w」: 在冒号输入字母「w」就可以将文件保存起来
「q」: 按「q」就是退出,如果无法离开vim,可以在**「q」后跟一个「!」强制离开vim**。
「wq」: 一般建议离开时,搭配「w」一起使用,这样在退出的时候还可以保存文件。
「x!」: 保存并退出编辑,仅当文件有修改时会保存,并修改文件时间属性

「: vs + 文件名」: 如在 test.c 中打开或创建一个文件「: vs liren.c 」

「ctrl + w」: 光标在分屏的多屏幕下进行切换

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

功能

将我们所写的高级语言代码编译解释成机器指令

格式

gcc [选项] 要编译的文件 [选项] [目标文件] 

编译过程

预处理:展开所有代码(引入头文件,宏替换,删除注释…)

编译:语法语义检测,没有错误则将代码解释成为汇编指令

汇编:架构汇编指令解释成二进制机器指令

链接:将所需的二进制机器指令(其他的.o以及库文件)打包生成可执行文件

 gcc 常见选项:

  • -E 只进行到预处理完成
  • -S 只进行到编译完成
  • -c 只进行到汇编完成
  • -o 指定要生成的目标文件对象名称
  • -g 告诉编译器不要生成release版本在 -c 时就要加上-g

 Linux调试器-gdb使用

背景

程序的发布方式有两种,debug模式和 release模式

Linux gcc/g++出来的二进制程序,默认是release模式

要使用gdb调试,必须在源代码生成二进制程序的时候, 加上 -g 选项

debug版本程序本身会被加入更多的调试信息,以便于进行调试。 

所以debug文件比生成默认的release文件大

gdb 的使用

gdb binFile 退出: ctrl + d 或 quit 调试命令

(list 或者 l)+ 行号:显示binFile源代码,接着上次的位置往下列,每次列10行

(list 或者 l)+ 函数名:列出某个函数的源代码

r 或 run: 运行程序,从开始连续而非单步执行程序

n 或 next: 单条执行,逐过程

s 或 step: 进入函数调用,逐语句

c(continue): 直接跳转到下一个断点

until X行号: 跳至X行

finish: 直接运行完毕对应的函数

b(break) + 行号:在某一行设置断点

b(break) + 函数名:在某个函数开头设置断点

i(info) b(break) : 查看断点信息

d(delete) b(breakpoints): 删除所有断点

d(delete) b(breakpoints) + 行号: 删除序号为 n 的断点

disable b(breakpoints): 禁用断点

enable b(breakpoints): 启用断点

p(print) + 变量或表达式: 打印表达式的值,通过表达式可以修改变量的值或者调用函数

display 变量名: 跟踪查看一个变量,每次停下来都显示它的值,==相当于vs中的监视==*

undisplay 变量名: 取消对先前设置的那些变量的跟踪

bt(breaktrace): 查看各级函数调用及参数,相当于vs中的调用堆栈窗口

i(info) locals: 查看当前栈帧局部变量的值set 变量名=n: 修改变量的值为 n

注意

调试程序完毕,或者调试中间过程,调试痕迹 很重要,当调试一个大的项目,可能有几十个断点,某个断点调试完了,不要直接把它删除,而是暂时禁用它,等程序没有任何问题了,再把所有断点删除。

 项目自动化构建工具 - make/Makefile (地球人都在用)

 make命令是用来自动完成大批量源文件编译工作的维护工具;能够建立不同文件之间的依赖关系自动识别被修改的源文件并重新编译,避免不必要的编译。(简言之,就是一个编译工具,并且非常实用。)

注:想要使用 make 命令,需要创建一个 makefile 文件 

准备工作、写法和用法

准备工作
首先将所有项目中要处理的文件放到同一个文件目录下,并且在该目录下新建一个名为Makefile的文件(推荐使用Makefile)。新建方法:在该目录下打开终端,输入如下命令即可。

vim Makefile

 规则的写法

对源文件(demo.c)处理将其生成对应的目标文件(即demo.o)

file:file.cgcc file.c -o file//注意:gcc前是一个Tab

目标文件file 依赖于原始文件 file.c,但光光有依赖关系是不能生成目标文件的,是不够的。

还需要有依赖方法,而 gcc file.c -o file 就是与之对应的依赖方法,表明如何生成目标文件 file。

编写makefile文件

file:file.c            # 表明了一种依赖关系,目标文件 file依赖于 file.c         gcc file.c -o file # 依赖方法,怎么用 file.c 生成目标文件 file(需要以tab键开头)
.PHONY:clean           # .PHONY —— "定义"伪目标:clean总是可以被执行的
clean:                 # 依赖项为空rm -rf file        # 清理可执行程序

 .PHONY 的作用

一般不会把可执行程序 “定义” 成伪目标,因为每次编译都是有成本的,第一次编译好了,就不需要再编译了,除非文件有改动。一般把清理可执行程序 “定义” 成伪目标。

 简化 makefile 文件

file:file.cgcc $^ -o $@          # $^: 可执行程序所依赖的文件列表 $@: 目标文件
.PHONY:clean
clean:rm -rf file

多文件项目,有 file.h file.c main.c 三个文件

file:file.c main.c       # 目标文件 test 依赖于 file.c 和 main.cgcc $^ -o $@         # $^: 可执行程序所依赖的文件列表 $@: 目标文件
.PHONY:clean
clean:rm -rf file
  • $@:表示依赖关系中的目标文件
  • $^ :表示依赖关系中的依赖文件列表
  • $< :表示依赖关系中的一个一个的依赖文件

make 是如何工作的

make 会在当前目录下找名字叫 “Makefile” 或 “makefile” 的文件。

如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到 “file” 这个文件,并把这个文件作为最终的目标文件。

如果 test 文件不存在,或是 test 所依赖的后面的 test.o 文件的文件修改时间要比 test 文件新,那么就会执行后面所定义的命令来生成 test 这个文件。

如果 test 所依赖的 test.o 文件不存在,那么 make 会在当前文件中找目标文件为 test.o 的依赖性,如果找到则再根据那一个规则生成 test.o 文件。

这就是整个 make 的依赖性,make 会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。在寻找的过程中,如果出现错误,比如最后被依赖的文件找不到,那么 make 会直接退出并报错(因为 make 只管文件的依赖性,不会管依赖的文件项到底在不在)。如果是所定义的命令的错误,或是程序编译不成功,make 不会理会。

 clean 项目清理

工程是需要被清理的。

比如 clean,如果没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要 make 执行。即命令 make clean,以此来清除所有的目标文件,以便重新编译。

一般会把 clean 设置为伪目标,用 .PHONY 修饰。(伪目标的特性是:总是被执行的)

分布式版本控制软件 - git 

1.在 gitee/github 创建新仓库:略,然后在创建好的仓库页面中复制远程仓库的地址 url,推荐 HTTPS。

2.克隆远程仓库到本地 

$ git clone [url]

执行命令后,输入 gitee/github 的用户名和密码,将会直接在本地创建一个放置代码的目录。

$ git add .                        # 添加所有文件到暂存区
$ git commit -m "本次提交的主题"    # 提交文件到本地仓库,""中写提交信息,不能乱写
$ git push                         # 推动本地仓库的文件到远程仓库

会提示设置用户名和邮箱(每次 git 提交都会使用到该信息,它被永远的嵌入到了你的提交中) (仓库有)

$ git config --global user.email "you@example.com" # 邮箱
$ git config --global user.name "Your Name"        # 用户名

 补充:

$ git log    # 查看所有提交日志信息
$ git status # 查看本地仓库所有文件状态

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/280631.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQLiteC/C++接口详细介绍sqlite3_stmt类(二)

返回目录&#xff1a;SQLite—免费开源数据库系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍sqlite3_stmt类简介 下一篇&#xff1a;SQLiteC/C接口详细介绍sqlite3_stmt类&#xff08;三&#xff09; sqlite3_reset() 功能&#xff1a;重置一个准备好执行的SQL语…

Mysql——基础命令集合

目录 前期准备 先登录数据库 一、管理数据库 1.数据表结构解析 2.常用数据类型 3.适用所有类型的修饰符 4.使用数值型的修饰符 二、SQL语句 1.SQL语言分类 三、Mysql——Create,Show,Describe,Drop 1.创建数据库 2.查看数据库 3.切换数据库 4.创建数据表 5.查看…

Flink RocksDB状态后端优化总结

截至当前&#xff0c;Flink 作业的状态后端仍然只有 Memory、FileSystem 和 RocksDB 三种可选&#xff0c;且 RocksDB 是状态数据量较大&#xff08;GB 到 TB 级别&#xff09;时的唯一选择。RocksDB 的性能发挥非常仰赖调优&#xff0c;如果全部采用默认配置&#xff0c;读写性…

风速预测(八)VMD-CNN-Transformer预测模型

往期精彩内容&#xff1a; 时序预测&#xff1a;LSTM、ARIMA、Holt-Winters、SARIMA模型的分析与比较-CSDN博客 风速预测&#xff08;一&#xff09;数据集介绍和预处理-CSDN博客 风速预测&#xff08;二&#xff09;基于Pytorch的EMD-LSTM模型-CSDN博客 风速预测&#xff…

Sora后时代文生视频的探索

一、写在前面 按常理&#xff0c;这里应该长篇大论地介绍一下Sora发布对各行业各方面产生的影响。不过&#xff0c;这类文章已经很多了&#xff0c;我们今天主要聊聊那些已经成熟的解决方案、那些已经可以“信手拈来”的成果&#xff0c;并以此为基础&#xff0c;看看Sora发布…

GB28181 —— 5、C++编写GB28181设备端,完成将USB摄像头视频实时转发至GB28181服务并可播放(附源码)

被测试的USB摄像头 效果 源码说明 主要功能模拟设备端,完成注册、注销、心跳等,同时当服务端下发指令播放视频时 设备端实时读取USB摄像头视频并通过OpenCV处理后实时转ps格式后封包rtp进行推送给服务端播放。 源码 /****@remark: pes头的封装,里面的具体数据的填写已经占…

远程传输大文件的软件 远程文件传输

在数字化时代&#xff0c;随着数据量的急剧增长&#xff0c;远程传输大文件变得越来越重要。无论是企业间的合作&#xff0c;还是个人的日常需求&#xff0c;高效、稳定、安全的远程文件传输都是关键。本文将介绍远程传输大文件的相关软件及其特点&#xff0c;帮助读者选择最适…

应急响应-Web2

应急响应-Web2 1.攻击者的IP地址&#xff08;两个&#xff09;&#xff1f; 192.168.126.135 192.168.126.129 通过phpstudy查看日志&#xff0c;发现192.168.126.135这个IP一直在404访问 &#xff0c; 并且在日志的最后几条一直在访问system.php &#xff0c;从这可以推断 …

Simulink|局部遮荫下光伏组件多峰值PSO-MPPT控制

目录 主要内容 1.光伏电池工程数学模型的输出特性程序 2.普通扰动观察法进行MPPT 3.基于粒子群寻优的多峰输出特性 4.PSO_MPPT仿真模型 下载链接 主要内容 在实际的光伏发电系统中&#xff0c;由于环境多变等因素的影响&#xff0c;当局部出现被遮挡情况时光伏阵列…

Beamer模板——基于LaTeX制作学术PPT

Beamer模板——基于LaTeX制作学术PPT 介绍Beamer的基本使用安装和编译用于学术汇报的模板项目代码模板效果图 Beamer的高级特性动态效果分栏布局定理环境 介绍 在学术领域&#xff0c;演示文稿是展示和讨论研究成果的重要方式。传统的PowerPoint虽然方便&#xff0c;但在处理复…

音频和视频标签

音频用audio标签 controls表示控制栏 loop循环播放音频 autoplay自动播放&#xff08;浏览器基于隐私一般不支持&#xff09; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Com…

k8s为什么删除了pod但是还是没删除掉的问题,deployment在影响

deployment 影响pod删除 一、问题所在二、解决问题 一、问题所在 执行&#xff1a;kubectl get pods --all-namespaces&#xff0c;获取dashboard相关的pod kubectl get pods --all-namespaces | grep dashboardkubectl delete pod dashboard-metrics-scraper-546d6779cb-4x6…

Python 深度学习第二版(GPT 重译)(二)

四、入门神经网络&#xff1a;分类和回归 本章涵盖 您的第一个真实世界机器学习工作流示例 处理矢量数据上的分类问题 处理矢量数据上的连续回归问题 本章旨在帮助您开始使用神经网络解决实际问题。您将巩固从第二章和第三章中获得的知识&#xff0c;并将所学应用于三个新…

回归预测 | Matlab基于SAO-LSTM雪消融算法优化长短期记忆神经网络的数据多输入单输出回归预测

回归预测 | Matlab基于SAO-LSTM雪消融算法优化长短期记忆神经网络的数据多输入单输出回归预测 目录 回归预测 | Matlab基于SAO-LSTM雪消融算法优化长短期记忆神经网络的数据多输入单输出回归预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab基于SAO-LSTM雪消融…

51单片机学习笔记8 中断系统及定时器

51单片机学习笔记8 中断系统及定时器 一、中断的概念二、51单片机的中断1. 51单片机的中断源2. 中断的优先级3. 中断结构4. 外部中断解读5. 定时器中断6. 串口中断 三、中断相关寄存器1. IE 中断允许寄存器2. TCON 中断请求标志3. IP 中断优先级 四、中断号五、代码实现按键 &a…

html5cssjs代码 029 CSS计数器

html5&css&js代码 029 CSS计数器 一、代码二、解释 该HTML代码定义了一个网页的结构和样式。在头部&#xff0c;通过CSS样式定义了body和h1-h2元素的样式。body元素的样式包括文本居中、计数器重置、字体颜色和背景颜色。h2元素的样式使用了CSS计数器来自动在标题前添加…

Web框架开发-Django模型层(数据库操作)

一、ORM介绍 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的工作量,不需要面对因数据库变更而导致的无效劳动ORM是“对象-关系-映…

stable diffusion webui ubuntu 安装

1.git clone 下来 GitHub - AUTOMATIC1111/stable-diffusion-webui: Stable Diffusion web UIStable Diffusion web UI. Contribute to AUTOMATIC1111/stable-diffusion-webui development by creating an account on GitHub.https://github.com/AUTOMATIC1111/stable-diffus…

RAFT: Adapting Language Model to Domain Specific RAG

预备知识 RAG介绍一文搞懂大模型RAG应用&#xff08;附实践案例&#xff09; - 知乎 (zhihu.com) RAG的核心理解为“检索生成” 检索&#xff1a;者主要是利用向量数据库的高效存储和检索能力&#xff0c;召回目标知识&#xff1b; 生成&#xff1a;利用大模型和Prompt工程…

Redis的分片机制

Redis的分片机制 Redis是一个开源的内存数据结构存储系统&#xff0c;它支持键值对的存储方式。Redis的分片机制允许将数据在多个节点上进行分布式存储和处理&#xff0c;从而提高系统的性能和可扩展性。 Redis的分片机制是通过一致性哈希算法实现的。一致性哈希算法将所有的ke…