Форум программистов, компьютерный форум CyberForum.ru

Виртуальные функции и деструктор - C++

Восстановить пароль Регистрация
 
19n1ght
2 / 2 / 0
Регистрация: 13.02.2013
Сообщений: 15
20.08.2013, 18:12     Виртуальные функции и деструктор #1
Доброго времени суток!

Прочел статью на Хабре Виртуальные функции и деструктор. В ней говорится, что в деструкторе ни в коем случае нельзя использовать виртуальные функции (т.к. в деструкторах и конструкторах используется ранее связывание).

Решил проверить. Написал следующий код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#include <iostream>
using namespace std;
 
class A {
public:
    A()
    {
        print("Created A");
    }
    virtual ~A() = 0
    {
        print("Deleted A");
    }
    virtual void print(const char *str) const
    {
        cout << str << endl;
    }
};
 
class B : public A {
public:
    B()
    {
        print ("Created B");
    }
    ~B() 
    {
        print ("Deleted B");
    }
};
 
void main()
{
    A *ptr = new B;
    delete ptr;
}
Все отработало так, как было задумано. На экран было выведено:
Created A
Created B
Deleted B
Deleted A
Вопрос: Можно ли использовать виртуальные функции в конструкторах и деструкторах? На Хабре и в книге Мейрса Effective C++ пишут, что нет. Но на практике все работает. Это было исправлено в последнем стандарте С++11 (статья на Хабре датирована 2010 годом, книга Мейрса, подозреваю, еще раньше) или я где-то ошибся и поэтому работает?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.08.2013, 18:12     Виртуальные функции и деструктор
Посмотрите здесь:

C++ Виртуальные функции
Виртуальные функции C++
C++ виртуальные и чисто виртуальные функции
C++ виртуальные функции С++
виртуальные функции C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11820 / 6799 / 769
Регистрация: 27.09.2012
Сообщений: 16,875
Записей в блоге: 2
Завершенные тесты: 1
20.08.2013, 18:29     Виртуальные функции и деструктор #2
Цитата Сообщение от 19n1ght Посмотреть сообщение
На Хабре и в книге Мейрса Effective C++ пишут, что нет. Но на практике все работает.
Виртуальность в деструкторах игнорируется
Dekio
Фрилансер
Эксперт C++
 Аватар для Dekio
5816 / 1214 / 214
Регистрация: 23.11.2010
Сообщений: 3,378
Записей в блоге: 1
20.08.2013, 18:30     Виртуальные функции и деструктор #3
Цитата Сообщение от 19n1ght Посмотреть сообщение
Можно ли использовать виртуальные функции в конструкторах и деструкторах?
Можно, но они "теряют" свою виртуальность
19n1ght
2 / 2 / 0
Регистрация: 13.02.2013
Сообщений: 15
20.08.2013, 18:32  [ТС]     Виртуальные функции и деструктор #4
Но ведь в моем примере виртуальность сохранилась. В деструкторе класса B я вызвал виртуальную функцию класса А и она сработала. Разве это не означает, что виртуальность функции в деструкторе сохранена?
Kastaneda
Модератор
Эксперт С++
 Аватар для Kastaneda
4236 / 2769 / 218
Регистрация: 12.12.2009
Сообщений: 7,104
Записей в блоге: 1
Завершенные тесты: 1
20.08.2013, 18:37     Виртуальные функции и деструктор #5
Цитата Сообщение от 19n1ght Посмотреть сообщение
Но ведь в моем примере виртуальность сохранилась.
Ты немного криво сделал, вот так попробуй
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <iostream>
using namespace std;
 
class A {
public:
    virtual ~A() = 0
    {
        print("Deleted");
    }
    virtual void print(const char *str) const
    {
        cout << "A(): " << str << endl;
    }
};
 
class B : public A {
public:
    
    virtual void print(const char *str) const
    {
        cout << "B(): " << str << endl;
    }
};
 
void main()
{
    A *ptr1 = new B;
    B *ptr2 = new B;
    delete ptr1;
    delete ptr2;
}
ожидается (всмысле если б виртуальность в деструкторах сохранялась), что вывод будет таким
Bash
1
2
B(): Deleted
B(): Deleted
но вывод такой
Bash
1
2
A(): Deleted
A(): Deleted
19n1ght
2 / 2 / 0
Регистрация: 13.02.2013
Сообщений: 15
20.08.2013, 18:43  [ТС]     Виртуальные функции и деструктор #6
Благодарю, теперь понятно.
Kastaneda
Модератор
Эксперт С++
 Аватар для Kastaneda
4236 / 2769 / 218
Регистрация: 12.12.2009
Сообщений: 7,104
Записей в блоге: 1
Завершенные тесты: 1
20.08.2013, 18:44     Виртуальные функции и деструктор #7
Цитата Сообщение от 19n1ght Посмотреть сообщение
В деструкторе класса B я вызвал виртуальную функцию класса А и она сработала
в твоем примере она бы сработала даже если бы не была виртуальной, она просто наследуется.
kvadro
11 / 9 / 1
Регистрация: 12.03.2012
Сообщений: 127
20.08.2013, 19:32     Виртуальные функции и деструктор #8
Kastaneda
Почему в производных классах тоже пишут virtual?
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
20.08.2013, 19:35     Виртуальные функции и деструктор #9
Цитата Сообщение от 19n1ght Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include <iostream>
using namespace std;
class A {
public:
* * A()
* * {
* * * * print("Created A");
* * }
* * virtual ~A() = 0
* * {
* * * * print("Deleted A");
* * }
* * virtual void print(const char *str) const
* * {
* * * * cout << str << endl;
* * }
};
class B : public A {
public:
* * B()
* * {
* * * * print ("Created B");
* * }
* * ~B() 
* * {
* * * * print ("Deleted B");
* * }
};
void main()
{
* * A *ptr = new B;
* * delete ptr;
}
А в чём в этом примере должна выражаться виртуальность?
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11820 / 6799 / 769
Регистрация: 27.09.2012
Сообщений: 16,875
Записей в блоге: 2
Завершенные тесты: 1
20.08.2013, 19:47     Виртуальные функции и деструктор #10
Цитата Сообщение от kvadro Посмотреть сообщение
Почему в производных классах тоже пишут virtual?
Можно и не писать
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.08.2013, 21:17     Виртуальные функции и деструктор
Еще ссылки по теме:

Виртуальные функции C++
C++ Виртуальные функции
Виртуальные функции C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
19n1ght
2 / 2 / 0
Регистрация: 13.02.2013
Сообщений: 15
20.08.2013, 21:17  [ТС]     Виртуальные функции и деструктор #11
Kuzia domovenok, я "накосячил". В первом примере нет виртуальности. Там обычное наследование, как верно подметил Kastaneda. Функция print() не была переопределенна в классе В.

Цитата Сообщение от kvadro Посмотреть сообщение
Kastaneda
Почему в производных классах тоже пишут virtual?
Действительно, это не обязательно. Ключевое слово virtual в производных классах можно опускать. Пишу для себя, чтобы отличать виртуальные функции от обычных.
Yandex
Объявления
20.08.2013, 21:17     Виртуальные функции и деструктор
Ответ Создать тему
Опции темы

Текущее время: 16:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru