【Linux系统】C/C++的调试器gdb/cgdb,从入门到精通

【Linux系统】C/C++的调试器gdb/cgdb,从入门到精通

各位读者大佬好,我是落羽!一个坚持不断学习进步的学生。
如果您觉得我的文章还不错,欢迎多多互三分享交流,一起学习进步!
也欢迎关注我的blog主页:
落羽的落羽

文章目录

一、调试前的预备知识

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

  • debug模式:生成的可执行程序中会包含程序的调试信息,便于程序员进行调试代码。
  • release模式:会剥离或不生成这些调试信息。这使得文件更小,但也意味着调试器几乎无法工作,release版本程序无法进行调试。

Linux的gcc/g++,按照我们之前的写法gcc -o $@ $^,默认生成的是release版本的程序,是无法进行调试的。要在命令后加-g选项,指定以debug方式发布,debug模式下的程序我们才能进行调试。

gcc -o $@ $^ -g 

二、gdb/cgdb的使用

1. 启动,查看代码

开始使用gdb/cgdb调试,首先要确定系统里已安装gdb/cgdb,其次要调试的程序确定是debug版本的。

gdb 文件名 

gdb和cgdb中,需要用各种指令完成调试过程的不同操作:

  • 退出调试:ctrl + d或输入quit回车

使用gdb,一开始是看不到我们的代码的,要使用l相关命令:

  • 输入(list)l:显示源代码,每次显示10行
  • 输入l 函数名/文件名:列出指定函数/指定文件的代码

输入l 文件名:行号:列出指定文件以某一行为中的几行代码

在这里插入图片描述

但是,实际开发中要靠自己显式出代码,还是很麻烦。因此cgdb诞生了,cgdb是gdb的前端界面增强版本,能够直接将代码显示在屏幕上面,初次之外其他命令操作没有区别:

在这里插入图片描述

后面我们就在cgdb中进行演示了。

2. 基础调试命令

  • 命令(run)r:开始调试,从程序开始执行,调试中途随时可以输入r重头调试
  • 命令(break)b [文件名:]行号:在指定行号设置断点
  • 命令info b:查看当前所有断点的信息
  • 命令d:删除所有断点
  • 命令d 断点序号:删除指定序号的断点

断点会在行号处标明:

在这里插入图片描述

每一个断点都有一个序号,通过info b查看,删除指定断点需要指明这个序号,而不是断点的行号:

在这里插入图片描述
  • 命令(continue)c:从当前位置开始连续执行程序,到下一个断点
  • 命令(next)n:单步逐过程执行,遇到函数时不进入函数内部
  • 命令(step)s:单步逐语句执行,遇到函数时进入函数内部
  • 命令(finish)f:执行到当前函数返回时
  • 命令until 行号:执行到指定行号
gdb/cgdb中,回车自动执行上一条命令

3. 监视变量相关命令

在调试过程中,我们经常需要观察一个变量的值:

  • 命令(print)p 变量/表达式:打印出变量/表达式的值。
  • 命令set var 变量 = 值:修改一个变量的值
  • 命令display 变量:持续显示一个变量的值
  • 命令undisplay 变量序号:取消对指定序号的变量的持续追踪显示
  • 命令watch 变量:监视一个变量的值,如果该变量的值在程序运行期间发生变化,cgdb会暂停程序的执行并通知用户。这一命令常用在,如果有不应该被修改的变量,你怀疑他被修改了,就可以watch他。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4. 设置条件断点

一个断点,也可以为其设置触发的条件。

b 位置 if 条件 #条件满足时,断点才会生效

举个栗子:b 10 if i == 5,表示在第10行新增一个断点,只有 i == 5 时才会生效

在这里插入图片描述

也可以给一个已存在断点新增触发条件:

condition 断点序号 条件 
在这里插入图片描述

非常好理解!

本篇完,感谢阅读

Read more

【Linux系统编程】(四十二)吃透线程互斥!从原理到实战,手把手教你玩转 Linux 下的互斥锁

【Linux系统编程】(四十二)吃透线程互斥!从原理到实战,手把手教你玩转 Linux 下的互斥锁

目录 前言 一、线程互斥的核心概念:搞懂这些,才算入门 1.1 共享资源与临界资源 1.2 临界区 1.3 互斥的定义 1.4 原子性:互斥的底层要求 二、多线程共享资源的坑:亲眼看看问题出在哪 2.1 问题代码:未加互斥的售票系统 2.2 编译运行与异常结果 2.3 问题根源:三步分析 (1)线程调度的随机性 (2)耗时操作放大了竞争问题 (3)ticket--本身不是原子操作 2.4 解决问题的核心要求 三、Linux 下的互斥量:mutex 的使用全解析 3.1 互斥量的类型与核心接口

By Ne0inhk

AI绘画技术演进:从DALL·E系列到Stable Diffusion家族的全面解析(附ControlNet实战指南)

1. AI绘画的“寒武纪大爆发”:从DALL·E到Stable Diffusion的演进之路 如果你在2022年之前告诉我,普通人敲几个字就能生成一张媲美专业画师的作品,我肯定会觉得你在讲科幻故事。但就在那一年,AI绘画领域仿佛经历了一场“寒武纪大爆发”,DALL·E 2和Stable Diffusion的横空出世,彻底改变了游戏规则。我记得当时我的社交媒体时间线被各种奇思妙想的AI画作刷屏,从“宇航员在月球上骑摩托车”到“蒸汽朋克风格的猫咪咖啡馆”,只有你想不到,没有AI画不出来。这股热潮背后,其实是两条清晰的技术发展脉络在交织前行:一条是以OpenAI为代表的DALL·E系列,走的是“大力出奇迹”的闭源精品路线;另一条则是以Stability AI为首的Stable Diffusion家族,高举开源大旗,催生了百花齐放的生态。我自己也是从那时起一头扎了进去,从最初看着参数一脸懵,到后来能熟练地调教模型生成想要的图,中间踩过的坑、熬过的夜,现在回想起来都是宝贵的经验。这篇文章,我就想以一个过来人的身份,帮你捋清这两大流派的技术演进逻辑,让你不仅知道它们“是什么”,更明白它们“为什么

By Ne0inhk
2026年高校AIGC检测新规解读:AI率多少算合格?

2026年高校AIGC检测新规解读:AI率多少算合格?

2026年高校AIGC检测新规解读:AI率多少算合格? 从2024年知网正式上线AIGC检测功能开始,短短两年时间,"AI率"已经从一个新鲜名词变成了每个毕业生必须面对的硬性指标。2026年,各高校的AIGC检测政策进一步收紧和细化,要求也越来越明确。 那么,2026年AI率到底多少才算合格?不同学校的标准差别大吗?不合格会面临什么后果?本文将对这些问题进行深入解读。 一、AIGC检测已成为毕业论文审查的标配 回顾AIGC检测在高校中的普及历程,可以用"指数级扩散"来形容: * 2024年:知网上线AIGC检测功能,少数985/211院校开始试点,大部分学校处于观望状态 * 2025年:超过60%的本科院校和80%的研究生培养单位将AIGC检测纳入论文审查流程 * 2026年:AIGC检测基本实现全覆盖,包括专科院校在内的绝大部分高等教育机构都已建立相关制度 这一进程的背后,是教育部在2025年初发布的《关于加强高等学校学位论文学术诚信管理的指导意见》,其中明确提到"鼓励各高校引入人工智能生成内容检测机制,将AIGC检测作为论文质量保障的重要环节"。 虽然教育部没

By Ne0inhk

AI绘画开源新星:Qwen-Image-2512技术亮点与部署趋势一文详解

AI绘画开源新星:Qwen-Image-2512技术亮点与部署趋势一文详解 最近,AI绘画圈又迎来了一颗重磅开源新星——阿里推出的Qwen-Image-2512。这个代号“2512”的最新版本,不仅在画质上有了肉眼可见的提升,还带来了更聪明的构图理解和更丰富的风格控制能力。对于咱们这些喜欢折腾AI绘画的开发者来说,这无疑是个值得深入研究的“新玩具”。 今天这篇文章,我就带大家从技术角度,好好盘一盘Qwen-Image-2512的核心亮点,并手把手教你如何通过ComfyUI这个强大的可视化工具,快速把它部署起来,跑出你的第一张惊艳作品。整个过程非常简单,哪怕你之前没怎么接触过ComfyUI,跟着步骤走也能轻松搞定。 1. Qwen-Image-2512:技术亮点深度解析 Qwen-Image-2512并非简单的版本迭代,它在多个关键维度上都做了显著优化。咱们先抛开那些复杂的论文术语,用大白话聊聊它到底“强”在哪。 1.1 画质与细节:肉眼可见的升级 最直观的感受就是画质。相比之前的版本,2512在图像清晰度、细节丰富度上进步明显。 * 分辨率与清晰度:模型对高分辨率图像

By Ne0inhk