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

news2024/11/22 16:18:20

 

目录

​编辑

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.c
	gcc 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.c
	gcc $^ -o $@          # $^: 可执行程序所依赖的文件列表 $@: 目标文件
.PHONY:clean
clean:
	rm -rf file

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

file:file.c main.c       # 目标文件 test 依赖于 file.c 和 main.c
	gcc $^ -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.coloradmin.cn/o/1532118.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java学习六—面向对象

一、关于面向对象 1.1简介 Java 是一种面向对象编程语言&#xff0c;其核心思想是面向对象编程&#xff08;Object-Oriented Programming&#xff0c;OOP&#xff09;。 面向对象编程是一种程序设计范式&#xff0c;它将数据与操作数据的方法&#xff08;函数&#xff09;捆…

有了std::thread,为什么还需要引入std::jthread?

C进阶专栏&#xff1a;http://t.csdnimg.cn/HGkeZ 目录 1.前言 2.std::is_invocable_v 3.std::jthread 3.1.构造函数 3.2.std::jthread无需join/detach使用实例 3.3.std::jthread处理外部请求中断实 3.4.处理中断请求示例代码 4.特性 5.总结 1.前言 C11以来提供了C原…

蓝桥杯刷题(十二)

1.答疑 代码 n int(input()) L [] for i in range(n):a,b,c map(int,input().split())A ab # 进入和答疑时间B abc # 个人总用时L.append([A,B]) L.sort(keylambda x:x[1]) # 个人总用时短的优先 ans tmp 0 # ans为发消息时刻&#xff0c;tmp为前一个人的总用时 for i …

【位运算】【 数学】【 哈希映射】2857. 统计距离为 k 的点对

本文涉及知识点 位运算 数学 哈希映射 LeetCode 2857. 统计距离为 k 的点对 给你一个 二维 整数数组 coordinates 和一个整数 k &#xff0c;其中 coordinates[i] [xi, yi] 是第 i 个点在二维平面里的坐标。 我们定义两个点 (x1, y1) 和 (x2, y2) 的 距离 为 (x1 XOR x2) …

数学建模-邢台学院

文章目录 1、随机抽取的号码在总体的排序2、两端间隔对称模型 1、随机抽取的号码在总体的排序 10个号码从小到大重新排列 [ x 0 , x ] [x_0, x] [x0​,x] 区间内全部整数值 ~ 总体 x 1 , x 2 , … , x 10 总体的一个样本 x_1, x_2, … , x_{10} ~ 总体的一个样本 x1​,x2​,……

【Leetcode每日一题】 递归 - 反转链表(难度⭐)(36)

1. 题目解析 题目链接&#xff1a;206. 反转链表 这个问题的理解其实相当简单&#xff0c;只需看一下示例&#xff0c;基本就能明白其含义了。 2.算法原理 一、递归函数的核心任务 递归函数的主要职责是接受一个链表的头指针&#xff0c;并返回该链表逆序后的新头结点。递归…

两台电脑简单的通信过程详解(局域网,同网段)

来源&#xff1a; https://www.bilibili.com/video/BV1BA411373b/ 一、原理 描述过程&#xff1a;分别以PC1、PC2、PC2、PC1的角度 二、eNSP测试 1.连接设备 2.查看PC1情况 3.打开抓包后&#xff0c;再ping一下PC2 4.PC1发送ARP报文 broadcast 意思为广播(IP都是f,意为255…

return code 1 from org.apache.hadoop.hive.ql.ddl.DDLTask

Bug信息 Error: Error while compiling statement: FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.ddl.DDLTask (state=08S01,code=1)Bug产生的代码 修复hive表分区: msck repair table xxxBug原因排查 分区数量过大 这个是网上查看的说如果一次…

2024.3.21 如何将idea的注释设置为在首字母前开始而不是句首

2024.3.21 如何将idea的注释设置为在首字母前开始而不是句首 两种写法的差异 修改办法 将右下角的勾去掉即可。

redis关联和非关联

1.1.2.关联和非关联 传统数据库的表与表之间往往存在关联&#xff0c;例如外键&#xff1a; 而非关系型数据库不存在关联关系&#xff0c;要维护关系要么靠代码中的业务逻辑&#xff0c;要么靠数据之间的耦合&#xff1a; {id: 1,name: "张三",orders: [{id: 1,ite…

手拉手整合Springboot3+RocketMQ2.3

RocketMQ 基本概念 消息模型Message Model RocketMQ 主要由 Producer、Broker、Consumer 三部分组成&#xff0c;其中 Producer 负责生产消息&#xff0c;Consumer 负责消费消息&#xff0c;Broker 负责存储消息。Broker 在实际部署过程中对应一台服务器&#xff0c;每个 Bro…

【报错】使用gradio渲染html页面无法加载本地图片

【报错】使用gradio渲染html页面无法加载本地图片 【报错】使用gradio渲染html页面无法加载本地图片[HTML] how to load local image by html output #884成功解决 【报错】使用gradio渲染html页面无法加载本地图片 在使用gradio框架渲染html页面&#xff0c;使用绝对路径&quo…

获取cookie

在Servlet9里设置cookie 在Servlet10里进行获取 访问Servlet9.do&#xff0c;再访问Servlet10.do

图书馆RFID(射频识别)数据模型压缩/解压缩算法实现小工具

1. 前言 最近闲来无聊&#xff0c;看了一下《图书馆射频识别数据模型第1部分&#xff1a;数据元素的设置及应用规则》以及《图书馆射频识别数据模型第2部分&#xff1a;基于ISO/IEC 15962的数据元素编码方案》&#xff0c;决定根据上面的编码方法实现一下该算法&#xff0c;于…

PyTorch 深度学习(GPT 重译)(五)

十二、通过指标和增强改进训练 本章涵盖 定义和计算精确率、召回率以及真/假阳性/阴性 使用 F1 分数与其他质量指标 平衡和增强数据以减少过拟合 使用 TensorBoard 绘制质量指标图 上一章的结束让我们陷入了困境。虽然我们能够将深度学习项目的机制放置好&#xff0c;但实…

聚类算法之层次聚类(Hierarchical Clustering)

注意&#xff1a;本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 &#xff08;[www.aideeplearning.cn]&#xff09; 层次聚类是一种非常独特和强大的聚类方法&#xff0c;与众多其他的聚类技术相比&#xff0c;它不仅为数据集提供了一个划分&#xff0c;还给出了…

3d模型文件导入时没颜色---模大狮模型网

导入3D模型文件时没有颜色显示通常是由于软件在显示模型时未正确解释颜色信息。这可能是由于模型文件本身没有包含颜色信息&#xff0c;或者是软件在导入过程中未正确处理颜色数据所致。 以下是一些可能的解决方法&#xff1a; 检查3D模型文件&#xff1a;首先&#xff0c;确保…

网络简略总结

目录 一、三次握手 四次挥手 1、三次握手:为了建立长链接进行交互即建立一个会话,使用http/https协议 2、四次挥手是一个断开连接释放服务器资源的过程 3、如果已经建立了连接,但是客户端突然出现故障了怎么办? 4、谁可以中断连接?客户端还是服务端还是都可以? 5、…

Linux环境开发工具之vim

前言 上一期我们已经介绍了软件包管理器yum&#xff0c; 已经可以在linux上查找、安装、卸载软件了&#xff0c;本期我们来介绍一下文本编辑器vim。 本期内容介绍 什么是vim vim的常见的模式以及切换 vim命令模式常见的操作 vim底行模式常见的操作 解决普通用户无法执行sudo问…

5G智能网关助力工业铸造设备监测升级

随着物联网技术的迅猛发展和工业4.0浪潮的推进&#xff0c;传统工业正面临着严峻的转型升级压力。在这一背景下&#xff0c;铸造行业——这一典型的传统重工业领域&#xff0c;也必须积极探索借助5G、物联网、边缘计算等技术提升生产经营效率的新路径。 本文就基于佰马合作伙伴…