glib gtk - 无效的类指针

时间:2013-03-23 11:41:35

标签: c class gtk glib

运行我的应用程序时出现此错误

GLib-GObject-WARNING **: gtype.c:3119: invalid class pointer `0xdfbb60'

通常会将GooCanvasGroup对象的子类传递给函数预览GooCanvasItem(这是一个接口类),但它不会在该特定点但在库内失败。

<cut> 
classes : 0xc73cb0 0xc73cb0 
<cut>
classes : 0xff3250 0xff3250 

(oregano:8482): GLib-GObject-WARNING **: gtype.c:3119: invalid class pointer `0x100a330'

Program received signal SIGTRAP, Trace/breakpoint trap.
0x00007ffff701ba27 in g_logv () from /usr/lib/libglib-2.0.so.0
(gdb) 
(gdb) bt
#0  0x00007ffff701ba27 in g_logv () from /usr/lib/libglib-2.0.so.0
#1  0x00007ffff701bbf2 in g_log () from /usr/lib/libglib-2.0.so.0
#2  0x00007ffff72f1dbd in g_type_interface_peek ()
   from /usr/lib/libgobject-2.0.so.0
#3  0x00007ffff7baf3dc in goo_canvas_item_update (item=0xb6c490, 
    entire_tree=entire_tree@entry=0, cr=cr@entry=0x7583d0, bounds=bounds@entry=
    0x7fffffffd3b0) at goocanvasitem.c:1698
#4  0x00007ffff7babbaf in goo_canvas_group_update (item=0xb6c370, entire_tree=
    0, cr=0x7583d0, bounds=0x7fffffffd440) at goocanvasgroup.c:615
#5  0x00007ffff7baf3ed in goo_canvas_item_update (item=0xb6c370, 
    entire_tree=entire_tree@entry=0, cr=cr@entry=0x7583d0, bounds=bounds@entry=
    0x7fffffffd440) at goocanvasitem.c:1700
#6  0x00007ffff7babbaf in goo_canvas_group_update (item=0xb6c130, entire_tree=
    0, cr=0x7583d0, bounds=0x7fffffffd4f0) at goocanvasgroup.c:615
#7  0x00007ffff7baf3ed in goo_canvas_item_update (item=0xb6c130, 
    entire_tree=entire_tree@entry=0, cr=cr@entry=0x7583d0, bounds=bounds@entry=
    0x7fffffffd4f0) at goocanvasitem.c:1700
#8  0x00007ffff7bc9425 in goo_canvas_update_internal (canvas=canvas@entry=
    0xc6e0d0, cr=cr@entry=0x7583d0) at goocanvas.c:2560
#9  0x00007ffff7bc9492 in goo_canvas_update (canvas=0xc6e0d0)
    at goocanvas.c:2592
#10 0x00007ffff7baf3a4 in goo_canvas_item_ensure_updated (item=item@entry=
    0xf0e670) at goocanvasitem.c:1676
#11 0x00007ffff7bb46e9 in goo_canvas_item_simple_get_bounds (item=0xf0e670, 
    bounds=0x7fffffffd640) at goocanvasitemsimple.c:1013
#12 0x00007ffff7baf21d in goo_canvas_item_get_bounds (item=0xf0e670, bounds=
    0x7fffffffd640) at goocanvasitem.c:1546
#13 0x000000000043ee77 in create_canvas_items (group=0xde4250, library_part=
    0x8be100) at ../../src/sheet/part-item.c:1176
#14 0x000000000043e841 in part_item_new (sheet=0xc6e0d0, part=0x10095c0)
    at ../../src/sheet/part-item.c:1083
#15 0x0000000000440bff in sheet_item_factory_create_sheet_item (sheet=
    0xc6e0d0, data=0x10095c0) at ../../src/sheet/sheet-item-factory.c:58
#16 0x000000000044730b in sheet_add_ghost_item (sheet=0xc6e0d0, data=0x10095c0)
    at ../../src/sheet/sheet.c:1139
#17 0x000000000042f610 in place_cmd (widget=0xcf9030, br=0xc8bb00)
    at ../../src/part-browser.c:191
#18 0x00007ffff72d3467 in ?? () from /usr/lib/libgobject-2.0.so.0
#19 0x00007ffff72ebe66 in g_signal_emit_valist ()
   from /usr/lib/libgobject-2.0.so.0
#20 0x00007ffff72ec6b2 in g_signal_emit () from /usr/lib/libgobject-2.0.so.0
#21 0x00007ffff69db198 in ?? () from /usr/lib/libgtk-3.so.0
#22 0x00007ffff72d3467 in ?? () from /usr/lib/libgobject-2.0.so.0
#23 0x00007ffff72ebe66 in g_signal_emit_valist ()
   from /usr/lib/libgobject-2.0.so.0
#24 0x00007ffff72ec6b2 in g_signal_emit () from /usr/lib/libgobject-2.0.so.0
#25 0x00007ffff69d9f03 in ?? () from /usr/lib/libgtk-3.so.0
#26 0x00007ffff6aa8f3f in ?? () from /usr/lib/libgtk-3.so.0
#27 0x00007ffff72d3467 in ?? () from /usr/lib/libgobject-2.0.so.0
#28 0x00007ffff72ebe66 in g_signal_emit_valist ()

我手动验证了类指针是错误的(读取:没有goocanvas,sheet-item,part-item类)

将该问题置于表面的最后一次调用是

            // the group is a "part-item" a subclass of "sheet-item" which is 
            // subclassed from "GooCanvasGroup"
    item = goo_canvas_polyline_new (GOO_CANVAS_ITEM (group), ... );

    g_assert (item!=NULL);
    g_assert (GOO_IS_CANVAS_ITEM (item));

    g_assert (group!=NULL);
    g_assert (GOO_IS_CANVAS_GROUP (group));
    g_assert (GOO_CANVAS_GROUP_GET_CLASS (group)!=NULL);
    g_printf ("classes : %p %p \n", GOO_CANVAS_GROUP_GET_CLASS(group), PART_ITEM_GET_CLASS (group));

    goo_canvas_item_get_bounds (item, &bounds);

但是,一旦我删除了goo_canvas_item_... - 请致电,goo_canvas_..的下一次通话将会失败。

所以我的怀疑是类声明/类型定义中出了问题:

片item.c

G_DEFINE_TYPE (SheetItem, sheet_item, GOO_TYPE_CANVAS_GROUP)

部分item.c

G_DEFINE_TYPE (PartItem, part_item, TYPE_SHEET_ITEM)

完整档案在这里:

https://github.com/drahnr/oregano/blob/master/src/sheet/sheet-item.c https://github.com/drahnr/oregano/blob/master/src/sheet/sheet-item.h https://github.com/drahnr/oregano/blob/master/src/sheet/part-item.c https://github.com/drahnr/oregano/blob/master/src/sheet/part-item.h

我很困惑什么可能导致这个问题,所以任何类型的提示都会受到赞赏。

编辑:如果有人想亲自尝试:

git clone git://github.com/drahnr/oregano.git
cd oregano
waf configure --prefix=/tmp debug install
gdb ./build/debug/oregano
(gdb) r
## click to time on the "place item"-button on the right side (bottom)
(gdb) bt

0 个答案:

没有答案