Linux 基础环境的开发工具以及使用(下)

 1. make / Makefile 自动化构建的工具

1)引入

在我们进行一些大型的工程的时候,代码量是极其大,当我们代码在进行一系列的编译的时候,难免会出现一些错误,当我们对错误进行一系列的更改之后,难道我们需要再重新敲刚刚一系列的相关指令吗?? 假设我们有上百个源代码,每一个都需要重新敲入相关的指令吗?? 这难免比较耗时。那有没有一些工具,可以进行对文件的相关编译原则,我们只需要输入指定的简短的指令,来完成对上百个源代码的编译。

make/Makefile 就是一个解决上述问题的自动化工具。

make:是一条指令

Makefile: 是一个包含一系列编译原则的文件通过调用make  指令来完成指定文件的编译。他用

于告诉 make 程序如何编译和链接一个程序。它包含了目标(target)、依赖关系

(dependencies)、命令(commands)等内容,使得我们可以通过简单的命令来构建和管理复杂

的软件项目。

2)使用

I)首先创建一个 makefile / Makefile 文件

touch makefile/Makefile

II) Makefile  里面的内容:存放依赖的 关系以及依赖方法

对指定文件进行预编译,编译,汇编,链接对应的指令 ,这里不再一一赘述,可见上篇博客文件编译对应的指定指令

III)在命令提示符里面直接使用meke 指令,就可以自动化完成指定文件的 编译。 

 注意:make 指令会自动推导对应的依赖关系,他的推导过程是一种栈式推导的;

一旦生成对应的第一个目标文件,此时就会停下来,其他 的对应目标文件不会生成,在默认的情

况下。也可以使用 make  + 指定的目标文件 

 3)相关问题

I) 为什么多次进行 make   的时候,显示以下的提示信息:该目标文件已经是最新的

分析:其实每次在进行 make 指令进行编译的时候,通过对比目标文件与源文件之间的“新旧” 时间,来决定是否再次执行make 指令。

II) 为什么会这样进行执行???

为了提高编译的效率。

一般情况下:首次进行编译的时候,目标文件是新于 源文件的,因为先有源文件,才有了对应的

目标文件(注意:这里的目标文件不仅仅指的是,汇编生成的目标文件,也可能是可执行文件或者

是预编译,编译生成对应的目标文件)。

当我们没有对源文件进行相应的修改,此时源文件是老于 目标文件的,假设当前make  指令会再

次生效,当源文件的体积很大时候,在进行编译的时候,会消耗大量的时间,所以为了提高编译

的效率,当源文件老于 目标文件的时候,不会再次执行make  指令。

本质:看源文件的内容是否发生变化,来决定是否再次进行make 指令的执行

4)对上面 的问题进行验证

编译器是如何知道当前的源文件的时间是 老于,还是新于 目标文件的呢???

首先需要知道几个时间:

access:记录对文件访问的时间

modify: 记录对文件内容的修改时间

change:记录对文件的属性修改时间

I) 查看一个文件的访问,修改,时间:stat

此时目标文件是新于 源文件的,所以当我们再次执行 make  的时候初出现以下的现象:

当我们对源文件进行修改的时候(对文件的内容或者是文件的属性进行修改),所见现象如下:

5)伪目标: .PHONY 的使用

当我们想 每次使用 make 的时候,都强制执行文件的编译,此时可以使用伪目标 .PHONY

对要生成的目标文件进行 .PHONY  伪目标的修饰

 但是一般不建议这样写,因为对于目标文件要是每次 make  的时候,都进行编译,这样不仅仅会消耗时间还极其销毁内存。但是对于文件的清理,可以使用 伪目标进行修饰。

2) make clean :文件清理

使用:直接在命令提示符使用 make clean 

2. git 

1)git  是什么

Git是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 

使用git 也可以进行团队合作。

git  的工作流程:

从远程仓库中克隆 Git 资源作为本地仓库;

从本地仓库中checkout代码然后进行代码修改;

提交本地仓库前先将代码提交到暂存区;

提交修改,提交到本地仓库;本地仓库中保存修改的各个历史版本;

在需要和团队成员共享代码时,可以将修改代码push到远程仓库。

2)git  的使用

I) 首先我们需要先创建一个远程仓库,具体实现细节见下:

 II) 把远程仓库拉取下来:先复制远程仓库的地址,具体实现细节见下

III)在命令行提示里面输入一下指令:

IIII) git  三板斧

git  add + 指定的文件

git  commit  -m  "关键 的文字说明"

git   push  :注意在这一步,会进行身份验证,输入git  的账号以及对应的密码即可

以上只是对git  的简单介绍,感兴趣的铁汁们,可以自行资料的搜集

3 . gdb 调试器的使用

1)引入

众所周知,Linux 是一个非图形化界面的操作系统(也支持图形化界面),在上面可以使用命令行的方式进行文件的创建,代码的编写,软件的下载…… 但是当我们的代码在进行运行的时候难免会遇到一些Bug ,此时又是如何调试的???

我们知道对于VS  下,进行代码的调试,有相关的按键支持,对于Linux 系统上,也是可以的,只不过这里是命令行的方式。

首先我们需要先下载 gdb 这个调试器。

sudo yum install -y gdb

gdb 是一个开发环境必不可少的调试工具。

2) Debug 和 Release  版本区别

当我们使用VS 进行代码运行的时候,多数是在 Debug 版本下进行的,方面我们进行相关的调试

简言之:Debug  版本,进行程序的调试。

对于测试人员:当我们把写好的项目进行终版的提交,他们会在 Release 版本下进行,主要

是发下各种问题,此时代码里面是不包调试信息的,也就是用户最终拿到的版本

3)Linux 下的gdb 相关的指令

I) 准备工作 :编一个测试代码

makefile  文件的内容:

gcc  默认进行文件编译采用的是版本是Debug ,当我们指定进行Debug 版本进行相关信息的调试 的

时候对应 的指令:对可执行程序进行编译的 时候,添加 -g  :进行debug  版本编译

 2)对指定程序进行调试  gdb + 可执行程序(注意这里 必须是可执行程序的文件)

如何判断当前的可执行程序到底是Debug  版本下生成的还是 Release  版本生成的???

 通过比较对应生成文件的大小:因为Debug  版本生成的文件,对应体积较大,因为需要包含一些

对应 的调试信息。

注意:gcc/g++ 编译生成对应的文件默认是以 release 版本发布的;想对知道程序进行调试 的时

候,必须借助 Debug  版本生成的程序:在编译的时候指定  -g 

当我们进入gdb 模式下,我们是无法知道当前代码的内容,此时可以借助  l 指令进行相关内容查找

 l + n  :查看当前代码指定的多少行,一般方便我们进行相关断点设置

l 0   和 l  1 打印出来的内容是一样的

当我们有了相关的内容,接下来就是如何进行打断点

b +指定的行号(源代码对应的某一行)

有了断点的设置,接下来就是如何查看已经打的断点???

info b

直接输入  info 的时候,默认是把所有的调试信息打印出来,如今我们只需要知道当前的 断点信息直接  info b

断点的删除:

d + 要删除断点对应的编号  对指定端点的删除

d breakpoints :删除所有 的断点

假设当前需要删除代码第7行对应的断点,此时就需要找到当前断点对应的编号: 3

程序的运行与调试:

r :遇到断点会停下来,相当于VS下的 F5 

逐过程 和逐语句的调试:

n :逐过程的调试,一般用于对函数的调试,相当于VS 下的 F10

s: 逐语句的调试,一个语句一个语句的调试,相当于VS 下的F11

当我们进入函数内部,发现这个执行的过程比较长,并且也不是出发报错的位置,想直接

该函数运行完,返回调用该函数的位置:直接使用  finish  指令即可

对变量的打印和追踪:

p + 变量名 : 显示变量的值

display + 变量名 : 每次运行完,都会打印一个当前变量对应的数值

对一个循环很长的代码块,此时一个一个指令的显示比较麻烦,可以使用diaplsy 进行追踪,此时

每执行一次循环,会自动打印变量的数值:

 当不需要对某个变量进行实时的跟踪的时候,使用undislay  进行设置。

 

以上是关于Linux 相关工具使用的简单介绍,后期会不定期的进行内容法更新~~~

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

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

相关文章

ERROR: KeeperErrorCode = NoNode for /hbase/master

原因分析 通过上面的情景模拟,我们可以看到报错的原因在于zookeeper中出现问题,可能是zookeeper中的/hbase/master被删除,或者是在hbase集群启动之后重新安装了zookeeper,导致zookeeper中的/hbase/master节点数据异常。 1. 停止…

【 C语言练习(4)—可自己设置游戏规则的猜数字游戏】

C语言练习(4) 文章目录 C语言练习(4)前言题目题目解析结果总结 前言 本次写的猜字游戏有两大优点,可重复玩游戏、可自己设置猜数字规则,通过猜数字游戏锻炼循环体和选择结构体 题目 写一个给定猜数次数&a…

【Vulkan入门】08-CreateRenderPass

目录 先叨叨git信息关键代码TestPipeLine::CreateRenderPass() 先叨叨 上篇已经为Pipeline编写好了程序(Shader)。接下来要为Pipeline创建RenderPass。 关于RenderPass,在【Vulkan入门】06-Pipeline介绍中已经作了简单的介绍。这里再详细说一…

【GitHub分享】you-get项目

【GitHub分享】you-get 一、介绍二、安装教程三、使用教程四、配置ffmpeg五,卸载 如果大家想要更具体地操作可去开源网站查看手册,这里只是一些简单介绍,但是也够用一般,有什么问题,也可以留言。 一、介绍 you-get是一…

【新】ApiHug官方文档-框架介绍-1/10

ApiHug SDK 扩展 https://apihug.com/zhCN-docs/frameworkApiHug SDK 扩展https://apihug.com/zhCN-docs/framework ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplacehttps://plugins.jetbrains.com/plugin/23534-apihug--api-design-copilot 快速开启 - …

06-标准库开发-STM32-SPI通信协议软件实现

八、SPI协议在STM32中的软件实现 8.1 SPI协议简介 SPI(Serial Peripheral Interface,串行外设接口)是由Motorola公司开发的一种同步串行数据通信总线。它主要用于微控制器与外设之间的短距离通信,如传感器、显示屏、存储器模块等…

C++ 中的隐式类型转换与强制类型转换详解

在 C 中,类型转换是一个非常重要的概念,涉及从一种数据类型向另一种数据类型的转换。本文将从 隐式类型转换 和 强制类型转换 两个方面详细探讨它们的行为和注意事项,特别是高位和低位的处理。 一、隐式类型转换 隐式类型转换(Im…

Redis篇-5--原理篇4--Lua脚本

1、概述 Redis 支持使用 Lua 脚本来执行复杂的操作,这为 Redis 提供了更强的灵活性和性能优化能力。通过 Lua 脚本,你可以在服务器端执行一系列命令,而不需要多次往返客户端与服务器之间,从而减少了网络延迟并提高了效率。此外&a…

Muduo网络库解析---事件循环模块

文章目录 前言ChannelChannel代码Channel.hChannel.cc PollerPoller代码Poller.hPoller.cc EpollPollerEpollPoller代码EpollPoller.hEpollPoller.cc EventLoopEventLoop代码EventLoop.hEventLoop.cc 类图 前言 重写Muduo库实现核心模块的Git仓库 注:本文将重点剖…

全面解析Node.js版本管理工具NVM

本文还有配套的精品资源,点击获取 简介:NVM(Node Version Manager)是一个强大的工具,用于在不同项目中管理多个Node.js版本。通过NVM,开发者可以轻松切换环境,优化工作流程,并提升…

第十七届山东省职业院校技能大赛 中职组“网络安全”赛项资源任务书样题②

第十七届山东省职业院校技能大赛 中职组“网络安全”赛项资源任务书样题② 模块A 基础设施设置与安全加固(200分)A-1 登录安全加固(Windows, Linux)A-2 Nginx安全策略(Linux)A-3日志监控(Windows)A-4中间件…

常用环境部署(二十四)——Docker部署开源物联网平台Thingsboard

1、Docker和Docker-compose安装 参考网址如下: CENTOS8.0安装DOCKER&DOCKER-COMPOSE以及常见报错解决_centos8安装docker-compose-CSDN博客 2、 Thingsboard安装 (1)在/home目录下创建docker-compose.yml文件 vim /home/docker-com…

Python定位Span标签中的文字:实战指南

目录 一、准备工作 二、基本流程 三、代码示例 四、案例分析 五、进阶技巧 处理多个标签: 根据其他属性定位: 结合XPath: 使用Selenium: 六、注意事项 七、总结 在网页数据抓取和信息提取的过程中,经常需要…

【K8S系列】在 Kubernetes 中使用 Prometheus 进行监控的详细指南

Prometheus 是一个开源的监控和报警工具,广泛用于 Kubernetes 环境中。本文将深入探讨如何通过 Kubernetes 中的注解配置 Prometheus 的抓取设置,以高效监控服务,并确保系统的可靠性和可维护性。 一、Prometheus 简介 Prometheus 是一个功能…

网页核心页面设计(第7章)

一、生态家居网页 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport" content"widthdevi…

Unix、GNU、BSD 风格中 ps 参数的区别

注&#xff1a;本文为“不同风格中 ps 命令参数的区别”相关文章合辑。 未去重。 BSD 风格和 UNIX 风格中 ps 参数的区别 作者&#xff1a;Daniel Stori 译者&#xff1a;LCTT Name1e5s | 2017-06-17 10:53 One Last Question ps aux 以及 ps -elf 都是查看进程的方式&…

vue前端实现导出页面为word(两种方法)

将vue页面导出为word文档&#xff0c;不用写模板&#xff0c;直接导出即可。 第一种方法(简单版) 第一步&#xff1a;安装所需依赖 npm install html-docx-js -S npm install file-saver -S第二步&#xff1a;创建容器&#xff0c;页面使用方法&#xff08;简单版&#xff1…

【C++】map

map 可以看到&#xff0c;map也有map和multimap两种。 可以看到第一个参数Key是key&#xff0c;第二个T其实就是value。第三个参数可以看出只有Key参与比较&#xff0c;value不进行比较。 map的Key就是map底层关键字的类型&#xff0c;T是map底层value的类型&#xff0c;set默…

专题一:斐波那契数列模型算法

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;了解什么是记忆化搜索&#xff0c;并且掌握记忆化搜索算法。 > 毒鸡汤&#xff1a;有些事情&#xff0c;总是不明白&#xff0c;所以我不会坚持。早…