Konstruktory dziedziczące

Dlaczego ten kod:

class A
{
    public: 
        explicit A(int x) {}
};

class B: public A
{
};

int main(void)
{
    B *b = new B(5);
    delete b;
}

Wynik tych błędów:

main.cpp: In function ‘int main()’:
main.cpp:13: error: no matching function for call to ‘B::B(int)’
main.cpp:8: note: candidates are: B::B()
main.cpp:8: note:                 B::B(const B&)

Czy B nie powinien dziedziczyć konstruktora A?

(This is using gcc)

Author: Rohit Vipin Mathews, 2008-12-07

6 answers

W C++03 standardowe konstruktory nie mogą być dziedziczone i trzeba je dziedziczyć ręcznie jeden po drugim przez wywołanie implementacji bazowej na własną rękę. Jeśli twój kompilator obsługuje standard C++11, istnieje dziedziczenie konstruktora. Aby dowiedzieć się więcej Zobacz Wikipedia C++11 Artykuł. Z nowym standardem piszesz:

class A
{
    public: 
        explicit A(int x) {}
};

class B: public A
{
     using A::A;
};
 282
Author: Suma,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2014-06-23 00:13:12

Konstruktory nie są dziedziczone. Są one wywoływane w sposób dorozumiany lub jawny przez konstruktor potomny.

Kompilator tworzy domyślny konstruktor (bez argumentów) i domyślny Konstruktor kopiujący(z argumentem, który jest odniesieniem do tego samego typu). Ale jeśli chcesz konstruktora, który będzie akceptował int, musisz go wyraźnie zdefiniować.

class A
{
public: 
    explicit A(int x) {}
};

class B: public A
{
public:
    explicit B(int x) : A(x) { }
};

UPDATE: W C++11 konstruktory mogą być dziedziczone. Zobacz odpowiedź Suma po szczegóły.

 82
Author: Avi,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-11-15 21:31:42

Musisz jawnie zdefiniować konstruktor w B i jawnie wywołać konstruktor dla rodzica.

B(int x) : A(x) { }

Lub

B() : A(5) { }
 6
Author: grepsedawk,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2012-03-07 06:33:29

To jest prosto z Bjarne Stroustrup ' s page :

Jeśli tak zdecydujesz, nadal możesz strzelić sobie w stopę, dziedzicząc konstruktory w klasie pochodnej, w której definiujesz nowe zmienne członkowskie wymagające inicjalizacji:

struct B1 {
    B1(int) { }
};

struct D1 : B1 {
    using B1::B1; // implicitly declares D1(int)
    int x;
};

void test()
{
    D1 d(6);    // Oops: d.x is not initialized
    D1 e;       // error: D1 has no default constructor
}
 3
Author: nenchev,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2015-05-11 12:58:36

Prawidłowy kod to

class A
{
    public: 
      explicit A(int x) {}
};

class B: public A
{
      public:

     B(int a):A(a){
          }
};

main()
{
    B *b = new B(5);
     delete b;
}

Błąd jest b / C Klasa B nie ma konstruktora parametru i po drugie powinna mieć inicjalizator klasy bazowej, aby wywołać konstruktor konstruktora parametru klasy bazowej

 1
Author: Iqbal Haider,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2014-02-20 07:48:08

Co powiesz na użycie funkcji szablonu do wiązania wszystkich konstruktorów?

template <class... T> Derived(T... t) : Base(t...) {}
 1
Author: Pradu,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2014-11-07 18:40:47