Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум на CrossPlatform.RU _ Qt Общие вопросы _ connect проблемы при наследовании

Автор: greh 2.7.2012, 18:01

При наследовании от класса, который уже наследует QObject возникает проблема регистрации (соединения) слотов дочернего класса:

QObject -> Parent -> Child

Данный код в конструкторе Child:

connect(anything, SIGNAL(destroyed()), this, SLOT(testSlot1()));

приводит к следуюшему сообщению:

QObject::connect: No such slot Parent::testSlot1() in ..\test\child.cpp:6

Т.е. при регистрации почему-то берётся базовый класс, а не текущий. Попытки приведения this к Child ни к чему не привели.

Parent.h:
Раскрывающийся текст
#ifndef PARENT_H
#define PARENT_H

#include <QObject>

class Parent : public QObject
{
    Q_OBJECT
public:
    explicit Parent(QObject *parent = 0);
};

#endif // PARENT_H

Parent.cpp:
Раскрывающийся текст
#include "parent.h"

Parent::Parent(QObject *parent) :
    QObject(parent)
{
}


Child.h:
Раскрывающийся текст
#ifndef CHILD_H
#define CHILD_H

#include "parent.h"

class Child : public Parent
{
public:
    Child();
public slots:
    void testSlot1();
};

#endif // CHILD_H

Child.cpp:
Раскрывающийся текст
#include "child.h"

Child::Child()
{
    QObject* anything = new QObject();
    connect(anything, SIGNAL(destroyed()), this, SLOT(testSlot1()));
}

Автор: Trisch 2.7.2012, 18:08

а попробуй сделать слот виртуальным и объявить в базовом классе.

Автор: greh 2.7.2012, 18:36

Цитата(Trisch @ 2.7.2012, 20:08) *
а попробуй сделать слот виртуальным и объявить в базовом классе.


Тогда в реальном приложении весь смысл абстракции теряется (QObject -> Player -> PhononPlayer). В последнем идёт работа уже с конкретными объектами Phonon, которые испускают специфические сигналы.

Автор: Trisch 3.7.2012, 15:36

А ты слот определил? А то я в коде чет это не заметил(

Автор: greh 3.7.2012, 16:22

Цитата(Trisch @ 3.7.2012, 17:36) *
А ты слот определил? А то я в коде чет это не заметил(

Разницы нет, результат один (да, пробовал с определённым).

Автор: greh 3.7.2012, 17:24

Вообщем на windows системах, а может и на всех, есть такой баг, который лечится только ручной чисткой папки с банарниками и make файлами или её удалением (очистка в креаторе не помогает).
Побробнее написано http://www.rsdn.ru/forum/cpp.qt/3731259.all.aspx(последнее сообщение).

На случай смерти ссылки:

Раскрывающийся текст
Цитата
Такое часто встречается вот в каком случае:

— создаешь хедер и срр, пишешь класс
— добавляешь в проект
— прогоняешь qmake
— потом добавляешь в класс слоты/сигналы

В этом случае при запуске qmake'а в п.3 не создаются вызовы moc'а, т.к. не было нужно. После добавления сигналов/слотов нужны вызовы moc'а для генерации стабов. Вот их и не хватает для vtable'а.
Простой повторный запуск qmake'а не спасает, надо удалить файлы object_script.XXX.debug и object_script.XXX.release.

P.S. Это на винде, на других платформах может быть немного иначе, но идея думаю понятна.

Ну и к тому же в Chid.h таки нужен макрос Q_OBJECT

Форум Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)