如何在gdb中打印<incomplete type =“”>变量</incomplete>

时间:2008-10-24 07:29:27

标签: gdb

有时gdb会为某些类型的变量打印“不完整类型”。这意味着什么?我们怎样才能看到这个价值?

5 个答案:

答案 0 :(得分:29)

这意味着该变量的类型未完全指定。例如:

struct hatstand;
struct hatstand *foo;

GDB知道foo是指向hatstand结构的指针,但该结构的成员尚未定义。因此,“不完整类型”。

要打印该值,您可以将其强制转换为兼容类型。

例如,如果您知道foo实际上是指向lampshade结构的指针:

print (struct lampshade *)foo

或者,您可以将其打印为通用指针,或将其视为整数:

print (void *)foo
print (int)foo

另请参阅GDB手册中的这些页面:

答案 1 :(得分:5)

我发现如果你反汇编一个使用不完整结构类型的函数,gdb'会发现'结构成员,然后可以显示它们。例如,假设您有一个字符串struct:

struct my_string {
    char * _string,
    int _size
} ;

通过指针创建和获取字符串的一些函数:

my_string * create_string(const char *) {...}
const char * get_string(my_string *){...}

和创建字符串的测试:

int main(int argc, char *argv[]) {
    my_string *str = create_string("Hello World!") ;
    printf("String value: %s\n", get_string(str)) ;
    ...
}

在gdb中运行它并尝试'print * str',你会得到一个'不完整类型'的响应。但是,尝试'反汇编get_string'然后'print * str'并且它将正确显示结构和值。我不知道为什么会这样,但确实如此。

答案 2 :(得分:0)

我遇到了同样的问题。如果您手动加载库中的符号:

set auto-solib-add off
attach thread_id
shared any_lib
shared another_lib

您需要使用相同的命令从声明此对象的库中加载符号。

答案 3 :(得分:0)

我不知道错误的全部含义,但正如彼得指出的那样,反汇编相关方法可以使某些类型定义可用。

我的例子:

在类的.h中,该类包含一个内部帮助器类的前向声明,以便外部类可以包含指向它的指针。相应的.cpp具有完整的内部辅助类定义。

在打破外部类的方法时,gdb通过外部类的实例报告了对内部类实例的指针的解除引用的不完整类型。

在外部类中的一个方法上发出disasemble命令,允许gdb使用先前失败的相同指针来理解内部类的结构。

答案 4 :(得分:0)

免责声明

我是一名Python开发人员,仅对C ++以及Linux OS的运行情况了解得很少,所以下面我所描述的只是我个人遇到的问题的解决方案。

如果您尝试使用来自第三方库的类型,请确保这些库没有缺少调试信息。

示例

(gdb) info share Qt
From                To                  Syms Read   Shared Object Library
0x00007ffff5336080  0x00007ffff56ba585  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5
0x00007ffff4ad3510  0x00007ffff4ef0cbe  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5
0x00007ffff47829c0  0x00007ffff47e1ba1  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5DBus.so.5
0x00007ffff40bb5e0  0x00007ffff439dd92  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Core.so.5
0x00007ffff2e581e0  0x00007ffff2e78e4f  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Xml.so.5
0x00007ffff28c8a00  0x00007ffff29d9999  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Network.so.5
0x00007ffff2251750  0x00007ffff2252a46  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5
0x00007ffff1cc9f80  0x00007ffff1cfc861  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5PrintSupport.so.5
0x00007fffee269c10  0x00007fffee297b57  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Svg.so.5
0x00007fffed987560  0x00007fffed98b6a8  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5TextToSpeech.so.5
0x00007fffe980e130  0x00007fffe9900c0c  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5XcbQpa.so.5
0x00007fffe69ef650  0x00007fffe69ffe0d  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5QuickControls2.so.5
0x00007fffe5c0f890  0x00007fffe5eae1c1  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Quick.so.5
0x00007fffe5522690  0x00007fffe581f636  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Qml.so.5
0x00007fffe51996b0  0x00007fffe5221363  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5QuickTemplates2.so.5
(*): Shared library is missing debugging information.

^当前示例中的所有Qt库都缺少调试信息。这是因为qt库的调试信息位于单独的软件包中,而这些软件包尚未安装。

每当我执行whatis时,一切都很好:

(gdb) whatis e
type = QEvent *

但是当我尝试访问它的成员时

(gdb) p e->type()
Couldn't find method QEvent::type

并尝试获取详细的类型描述

(gdb) ptype e
type = class QEvent {
  <incomplete type>
} *

解决方案(对于Ubuntu上的Qt)

  1. 查找文件在OS发行版中属于哪个包
$ dpkg -S /usr/lib/x86_64-linux-gnu/libQt5Core.so.5
libqt5core5a:amd64: /usr/lib/x86_64-linux-gnu/libQt5Core.so.5
  1. 搜索相关软件包

    使用关键字libqt5core5a搜索将返回2个软件包,一个是libqt5core5a本身,另一个是libqt5core5a-dbgsym。后者的描述为:“ libqt5core5a的调试符号”

  2. 安装带有调试符号的软件包(我还为其他一些基本的Qt库安装了调试符号)

$ sudo apt install libqt5core5a-dbgsym libqt5widgets5-dbgsym libqt5gui5-dbgsym
  1. gdb中确保库现在具有调试信息
(gdb) info share Qt
From                To                  Syms Read   Shared Object Library
0x00007ffff5336080  0x00007ffff56ba585  Yes         /usr/lib/x86_64-linux-gnu/libQt5Widgets.so.5
0x00007ffff4ad3510  0x00007ffff4ef0cbe  Yes         /usr/lib/x86_64-linux-gnu/libQt5Gui.so.5
0x00007ffff47829c0  0x00007ffff47e1ba1  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5DBus.so.5
0x00007ffff40bb5e0  0x00007ffff439dd92  Yes         /usr/lib/x86_64-linux-gnu/libQt5Core.so.5
0x00007ffff2e571e0  0x00007ffff2e77e4f  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Xml.so.5
0x00007ffff28c7a00  0x00007ffff29d8999  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Network.so.5
0x00007ffff2250750  0x00007ffff2251a46  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5X11Extras.so.5
0x00007ffff1cc8f80  0x00007ffff1cfb861  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5PrintSupport.so.5
0x00007fffee268c10  0x00007fffee296b57  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Svg.so.5
0x00007fffed985560  0x00007fffed9896a8  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5TextToSpeech.so.5
0x00007fffe95fc130  0x00007fffe96eec0c  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5XcbQpa.so.5
0x00007fffe701f650  0x00007fffe702fe0d  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5QuickControls2.so.5
0x00007fffe623c890  0x00007fffe64db1c1  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Quick.so.5
0x00007fffe5b4f690  0x00007fffe5e4c636  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5Qml.so.5
0x00007fffe57c66b0  0x00007fffe584e363  Yes (*)     /usr/lib/x86_64-linux-gnu/libQt5QuickTemplates2.so.5
(*): Shared library is missing debugging information.
  1. 现在使用Qt类型可以正常工作
(gdb) p e->type()
$4 = QEvent::Paint
(gdb) ptype e
type = class QEvent {
  public:
...
}