Наследовать сигнал в libs

Я использую библиотеку libsourcey для обучения. Я пытаюсь написать новый класс, который наследует класс с именем Signal.

в свободном доступе

template <typename RT> class Signal;
template <typename RT, typename... Args> class Signal<RT(Args...)> {...}

и мой путь

template <typename RT> class NewSignal;
template <typename RT, typename... Args> class NewSignal<RT(Args...)> : public Signal<RT(Args...)> {...}

но я не могу получить доступ к любому свойству класса Signal, а также атрибута (хотя я изменяю атрибут для общественности). Отчет Complier (затмение): was not declared in this scope

пример

У меня 2 класс

класс B

template<class RT> class B;

template<class RT, class... Args>
class B<RT(Args...)> {
public:
    B(int value = 0) : m_i(value) {}
    ~B() {}
    void print() {
        std::cout << "i = " << m_i << std::endl;
    }
    int m_i;
};

класс А

template<class RT> class A;

template<class RT, class... Args>
class A<RT(Args...)> : public B<RT(Args...)> {
public:
    A(int value = 0) : B<RT(Args...)>(value) {}
    virtual ~A() {}
    void print() {
        std::cout << "i = " << 2 * m_i << std::endl;
    }
};

При сборке я получаю ошибку

и main.cpp

#include "Aclass.hpp"
#include "Bclass.hpp"

int main(int argc, char* argv[]) {
    B<void(void)> b(1);
    b.print();
    A<void(void)> a(2);
    a.print();
    return 0;
}

Но когда я изменюсь std::cout << "i = " << 2 * m_i << std::endl; в классе А до std::cout << "i = " << 2 * B<RT(Args...)>::m_i << std::endl; затем сборка завершена, ошибок нет.

Кто-нибудь объяснит, почему отчет компилятора такой. Как я могу унаследовать класс сигнала. Если нет, есть какое-нибудь решение? Спасибо за поддержку.

0 ответов

Другие вопросы по тегам