当前位置: 首页 > news >正文

GDB 调用之ptype、set variable

        今天在公司的时候,排查一个问题,创建l3 lif 失败,查看各种日志发现是用key去创建的 lif失败了,日志里指示key为空,导致的创建失败。原因为一个结构体比基线的多了一些东西,导致版本不对,既而计算出来的key不对。调试过程中用到了 ptype 打印结构体变量的类型,结果看基线分支代码却对应不上,比基线代码的结构体多了一个 union 变量。以下只作一下练习:

#include <map>
#include <string>
#include <stdlib.h>
#include <stdio.h>enum
{TYPE_ID_0,TYPE_ID_1,TYPE_ID_2,TYPE_ID_3,TYPE_ID_4,TYPE_ID_5,TYPE_ID_6,TYPE_ID_MAX
};
typedef struct mapData
{int id;char *p;std::string key;
}MapData;std::map<std::string, MapData> g_mapData[TYPE_ID_MAX];int changeMap(int type);
int main()
{changeMap(2);for(int i = 0 ; i < TYPE_ID_MAX; i++){auto data = g_mapData[i];//for(auto it : data)for(auto ite = data.begin(); ite != data.end(); ite++){//printf("i = %d, string: %s, id = %d, key = %s\n", i, it.first.c_str(), it.second.id, it.second.key.c_str());printf("i = %d, string: %s, id = %d, key = %s\n", i, ite->first.c_str(), ite->second.id, ite->second.key.c_str());}}return 0;
}int changeMap(int type)
{int a = 100;auto &data = g_mapData[type];char test[] = "test";MapData newData = {20, test, "2000"};data["1"] = newData;data.insert(std::pair<std::string, MapData>("2", newData));return 0;
}

用GDB调试,打一个断点:

 我们可以看到如果是结构体类型,则会打印出来结构体的成员,如果是map类型会打印出什么呢?

 如果要改变变量的值,可以使用命令 set variable xx=xx,如:

如果是结构体类型该怎么赋值呢?先看一下最简单的,结构里就一个基本的类型:

#include <map>
#include <string>
#include <stdlib.h>
#include <stdio.h>enum
{TYPE_ID_0,TYPE_ID_1,TYPE_ID_2,TYPE_ID_3,TYPE_ID_4,TYPE_ID_5,TYPE_ID_6,TYPE_ID_MAX
};
typedef struct mapData
{int id;
}MapData;std::map<std::string, MapData> g_mapData[TYPE_ID_MAX];int changeMap(int type);
int main()
{changeMap(2);for(int i = 0 ; i < TYPE_ID_MAX; i++){auto data = g_mapData[i];//for(auto it : data)for(auto ite = data.begin(); ite != data.end(); ite++){//printf("i = %d, string: %s, id = %d, key = %s\n", i, it.first.c_str(), it.second.id, it.second.key.c_str());//printf("i = %d, string: %s, id = %d, key = %s\n", i, ite->first.c_str(), ite->second.id, ite->second.key.c_str());}}return 0;
}int changeMap(int type)
{int a = 100;auto &data = g_mapData[type];char test[] = "test";MapData newData = {20};data["1"] = newData;data.insert(std::pair<std::string, MapData>("2", newData));return 0;
}

打个断点,查看一下结构体的值,然后再修改一下,看结果:

如果是复杂的结构体呢?如:

typedef struct mapData
{int id;char *p;std::string key;
}MapData;

 结构体里有指针,有std::string 类型,这时候该怎么赋值呢?

结果有点不一样,即使第二个成员是指针,我们临时给它赋了一个值,也是正常的,但std::string却显示为空,为何?我们看一下std::string 的源码:

string 保存的是一个指针,指针指向的才是真正的数据,那我们可以看一下这个指针指向的地址是不是保存着我们给它赋的值 “aaa” :

首先打印出key的地址,再根据它的地址看内存里保存了哪些值,其中 0x00607060 就是std::string 私有成员 _M_dataplus的值,因为它是一个指针,指向的是string 的内容。但为何在GDB里直接打印结构体却显示为空呢?有知道的大神指点一下。

 

 

 

http://www.lryc.cn/news/39291.html

相关文章:

  • 并发编程---阻塞队列(五)
  • 本科课程【计算机组成原理】实验1 - 输出ABCD程序的生成
  • Java并发编程(2) —— 线程创建的方式与原理
  • 你写的js性能有多差你知道吗 | js性能优化
  • 线程的状态、状态之间的相互转换
  • Java8使用Lambda表达式(流式)快速实现List转map 、分组、过滤等操作
  • C++之深浅拷贝
  • CoreLocation的一切
  • HashMap原理
  • STM32入门笔记(02):独立看门狗(IWDG)和窗户看门狗(WWDG)(SPL库函数版)
  • javaSE系列之方法与数组的使用
  • 常用命令总结
  • 【Linux:程序地址空间--原来操作系统也喜欢画大饼】
  • Python实现简单信号滤波实战
  • Java(110):非对称加密RSA的使用(KeyPair生成密钥)
  • (Mybatis 学习【1】)整合 Mybatis 开发流程
  • 一文搞懂Kerberos
  • Go爬虫学习笔记(三)
  • CASTEP参数设置(2)
  • 浅谈对Promise的理解以及在工作中的应用
  • 开源|快速入门和理解并模拟实现GPS户外机器人的定位与导航
  • Java多线程系列--synchronized的原理
  • QEMU启动ARM64 Linux内核
  • Linux->进程程序替换
  • 最强分布式锁工具:Redisson
  • Java9-17新特性
  • 电脑开机找不到启动设备怎么办?
  • 使用langchain打造自己的大型语言模型(LLMs)
  • assert()宏函数
  • Docker圣经:大白话说Docker底层原理,6W字实现Docker自由