如何在新结构中使指针兼容?

问题描述 投票:3回答:2

我正在尝试'继承'一个GtkWidget。我可以继承任何其他小部件,如GtkWindow等,并在自己的文件中实现其方法。然后我将使用一个函数加载新的小部件,该函数返回小部件,就像return g_object_new(...一样。

代码工作正常,但我在struct init函数中得到不兼容的指针类型警告。

class.h

#ifndef CLASS_H_INCLUDED
#define CLASS_H_INCLUDED

#include <gtk/gtk.h>
#define CLASS_NAME_TYPE (class_name_get_type())
G_DECLARE_FINAL_TYPE(ClassName, class_name, CLASS, NAME, GtkWidget)

ClassName *class_name_new();

#endif // CLASS_H_INCLUDED

class.c

#include "class.h"

struct _ClassName
{
  GtkWidget parent;
};

G_DEFINE_TYPE(ClassName, class_name, GTK_TYPE_WIDGET);

static void class_name_init(ClassName *self)
{
    gtk_widget_set_name(self, "Widget");
}

static void class_name_class_init(ClassNameClass *klass)
{

}

ClassName *class_name_new()
{
    return g_object_new(CLASS_NAME_TYPE, /* "foo", bar ,*/ NULL);
}

在函数static void class_name_init(ClassName *self)中,我想像这样使用指针self

gtk_widget_set_name(self, "Widget");

这是我有兼容的指针类型的地方。 gtk_widget_set_name()期望类型为GtkWidget作为输入,但init函数的类型为ClassName。

Gtk知道ClassName与GtkWidget是相同的类型,因此代码可以工作,但无论如何都要修复代码,以便编译器不认为它是一个错误

c struct gtk typedef
2个回答
2
投票

通常,您应该使用强制转换操作符来避免编译器警告,假设self是一个指针:

gtk_widget_set_name((GtkWidget*)self, "Widget");

1
投票

定义对象也像GTK_WIDGET(obj)一样工作

代替

gtk_widget_set_name(self, "Widget"); 

gtk_widget_set_name(GTK_WIDGET(self), "Widget");`

如果self是一个窗口GTK_WINDOW(self),你总是可以定义对象

© www.soinside.com 2019 - 2024. All rights reserved.