Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
RAFA91
Заблокирован
#1

Исключительные ситуации (повторный вызов деструктора)

05.06.2015, 15:22. Просмотров 1332. Ответов 59
Метки нет (Все метки)

Всем привет !

Подскажите пожалуйста , почему повторно вызываются деструкторы класса A,B,C?

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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include <stdio.h>
#include <conio.h>
 
class Ana
 
{
    int x;
 
public:
 
    Ana(int c); 
 
    ~Ana() {}
    
    int ghf() const {return x;}
 
    class A 
    
    { 
    
    public: 
        
        A() {printf("\nKONSTRUKTOR A %p\n",this);}
 
        ~A() {printf("\nDESTRUKTOR A %p\n",this);}
    };
 
    class B : public A 
    
    {
    
    public: 
        
        B() {printf("\nKONSTRUKTOR B %p\n",this);}
 
        ~B() {printf("\nDESTRUKTOR B %p\n",this);}
    };
 
    class C : public B 
    
    {
    
    public: 
        
        C() {printf("\nKONSTRUKTOR C %p\n",this);}
 
        ~C() {printf("\nDESTRUKTOR C %p\n",this);}
    };
};
 
Ana :: Ana(int c) :
 
x(c)
 
{
    if(c == 0) throw B();
 
    if(c < 0) throw A();
 
    if(c > 10) throw C();
}
 
int main()
 
{
    try
 
    {
        Ana s(11);
 
        printf("\n-------- %d\n",s.ghf());
    }
 
 
    catch (Ana :: C)
 
    {
        printf("\n****** c > 10\n");
    }
 
    catch (Ana :: B)
 
    {
        printf("\n****** c == 0\n");
    }
 
 
    catch (Ana :: A)
 
    {
        printf("\n****** c < 0\n");
    }
        
 
        getch();
 
        return 0;
}
0
Миниатюры
Исключительные ситуации (повторный вызов деструктора)  
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.06.2015, 15:22
Ответы с готовыми решениями:

Повторный вызов деструктора
{ bar b; b.~bar(); } В данном примере деструктор bar вызовется дважды. ...

Повторный вызов деструктора для объекта
Здравствуйте! К сожалению, я пока не умею пользоваться отладчиком для...

исключительные ситуации
Описать и реализовать функцию анализа номера телефона, обработайте ошибку...

Исключительные ситуации
Как обработать исключительную ситуацию,когда переменная описана как int,к...

исключительные ситуации
Подскажите, как сделать переполнение в этой задаче: Создать класс для хранения...

59
Croessmah
++Ͻ
14503 / 8285 / 1556
Регистрация: 27.09.2012
Сообщений: 20,338
Записей в блоге: 3
Завершенные тесты: 1
05.06.2015, 15:29 #2
Забыли про конструкторы копирования
1
RAFA91
Заблокирован
05.06.2015, 16:01  [ТС] #3
а при чем тут копирование ?

я же нечего не передаю в функцию как значение .
0
Tulosba
:)
Эксперт С++
4747 / 3241 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
05.06.2015, 16:08 #4
Цитата Сообщение от RAFA91 Посмотреть сообщение
а при чем тут копирование ?
Лишнее копирование происходит из-за ловли исключения по значению, а не по ссылке.
1
RAFA91
Заблокирован
05.06.2015, 17:49  [ТС] #5
и куда этот обьект идет ?

в catch ?
0
castaway
Эксперт С++
4929 / 3036 / 453
Регистрация: 10.11.2010
Сообщений: 11,116
Записей в блоге: 10
Завершенные тесты: 1
05.06.2015, 17:53 #6
C++
1
catch ( Ana::C & )
1
RAFA91
Заблокирован
06.06.2015, 12:14  [ТС] #7
castaway в данном случае , что имеется ввиду ?

передача обьекта в catch как ссылки ?

сделал так , но всеравно получаю повторный вызов деструктора (((

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 catch (Ana :: C &a)
 
    {
        printf("\n****** c > 10\n");
    }
 
    catch (Ana :: B &a)
 
    {
        printf("\n****** c == 0\n");
    }
 
 
    catch (Ana :: A &a)
 
    {
        printf("\n****** c < 0\n");
    }
0
castaway
Эксперт С++
4929 / 3036 / 453
Регистрация: 10.11.2010
Сообщений: 11,116
Записей в блоге: 10
Завершенные тесты: 1
06.06.2015, 13:05 #8
Цитата Сообщение от RAFA91 Посмотреть сообщение
сделал так , но всеравно получаю повторный вызов деструктора (((
А у меня нет повторного вызова деструктора.
1
Alex5
1122 / 783 / 232
Регистрация: 12.04.2010
Сообщений: 2,012
06.06.2015, 13:06 #9
Лучший ответ Сообщение было отмечено RAFA91 как решение

Решение

RAFA91, вот пример.
1
RAFA91
Заблокирован
06.06.2015, 13:27  [ТС] #10
Alex5 тут я увидел вызов копировщика.

я написал следующее

C++
1
2
3
4
5
catch (Ana :: C &a)
 
catch (Ana :: B &a)
 
catch (Ana :: A &a)
и получид это.

как я понял второй раз деструктора вызываются при выходе из catch .

тогда первый раз когда они вызываются ?

не могу понять зачем первый раз они вызываются , если я в catch передаю обьект как ссылку (((
0
Миниатюры
Исключительные ситуации (повторный вызов деструктора)  
castaway
Эксперт С++
4929 / 3036 / 453
Регистрация: 10.11.2010
Сообщений: 11,116
Записей в блоге: 10
Завершенные тесты: 1
06.06.2015, 13:31 #11
Покажи полный код.
1
RAFA91
Заблокирован
06.06.2015, 13:53  [ТС] #12
какой-то бред лезит и лезит.

по идеи должен получать сообщения от копировщиков

C++
1
A(const A & rhs) {printf("\nKONSTRUKTOR A copy %p %p\n",this,& rhs);}
C++
1
    B(const B & rhs) {printf("\nKONSTRUKTOR B copy %p %p\n",this,& rhs);}
C++
1
C(const C & rhs) {printf("\nKONSTRUKTOR C copy %p %p\n",this,& rhs);}
но увы получаю это

_______________________

полный код

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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#include <stdio.h>
#include <conio.h>
 
class Ana
 
{
    int x;
 
public:
 
    Ana(int c); 
 
    ~Ana() {}
    
    int ghf() const {return x;}
 
    class A 
    
    { 
    
    public: 
        
        A() {printf("\nKONSTRUKTOR A %p\n",this);}
 
        A(const A & rhs) {printf("\nKONSTRUKTOR A copy %p %p\n",this,& rhs);}
 
        ~A() {printf("\nDESTRUKTOR A %p\n",this);}
    };
 
    class B : public A 
    
    {
    
    public: 
        
        B() {printf("\nKONSTRUKTOR B %p\n",this);}
 
        B(const B & rhs) {printf("\nKONSTRUKTOR B copy %p %p\n",this,& rhs);}
 
        ~B() {printf("\nDESTRUKTOR B %p\n",this);}
    };
 
    class C : public B 
    
    {
    
    public: 
        
        C() {printf("\nKONSTRUKTOR C %p\n",this);}
 
        C(const C & rhs) {printf("\nKONSTRUKTOR C copy %p %p\n",this,& rhs);}
 
        ~C() {printf("\nDESTRUKTOR C %p\n",this);}
    };
};
 
Ana :: Ana(int c) :
 
x(c)
 
{
    if(c == 0) throw B();
 
    if(c < 0) throw A();
 
    if(c > 10) throw C();
}
 
int main()
 
{
    try
 
    {
        Ana s(11);
 
        printf("\n-------- %d\n",s.ghf());
    }
 
 
    catch (Ana :: C )
 
    {
        printf("\n****** c > 10\n");
    }
 
    catch (Ana :: B )
 
    {
        printf("\n****** c == 0\n");
    }
 
 
    catch (Ana :: A )
 
    {
        printf("\n****** c < 0\n");
    }
        
 
        getch();
 
        return 0;
}
______________

тут получаю вызов только от одного копировщика (((

http://ideone.com/L9yL5Y
0
Миниатюры
Исключительные ситуации (повторный вызов деструктора)  
castaway
Эксперт С++
4929 / 3036 / 453
Регистрация: 10.11.2010
Сообщений: 11,116
Записей в блоге: 10
Завершенные тесты: 1
06.06.2015, 14:02 #13
А ты не пробовал сначала решать одну проблему, а потом перейти к другой?
То у тебя деструкторы по два раза вызываются, то уже сразу конструктор копирования откуда то появился.
Что с той проблемой?
1
Alex5
1122 / 783 / 232
Регистрация: 12.04.2010
Сообщений: 2,012
06.06.2015, 14:08 #14
Цитата Сообщение от RAFA91 Посмотреть сообщение
тут получаю вызов только от одного копировщика (((
C++
1
2
3
4
5
6
7
8
9
class C : public B 
{
public: 
C() {printf("\nKONSTRUKTOR C %p\n",this);}
C(const C & rhs)                  /*  так как явно не указано, какой  конструктор вызывать,      */
                                        /*     здесь будет вызван к-тор без параметров B::B() */
{
    printf("\nKONSTRUKTOR C copy %p %p\n",this,& rhs);
}
1
RAFA91
Заблокирован
06.06.2015, 14:14  [ТС] #15
Вы не поверите , но когда я тупо прописал в классах A,B,C копировщики , то проблема ушла.

но зато всплыла другая.

Alex5 показал результат работы программы

у меня этот результат сильно отличается

у него аж 3 раза вызвался копировщик , а у меня только один раз.

В чем проблема ?

___________________________

http://ideone.com/8hYEgj
0
castaway
Эксперт С++
4929 / 3036 / 453
Регистрация: 10.11.2010
Сообщений: 11,116
Записей в блоге: 10
Завершенные тесты: 1
06.06.2015, 14:16 #16
Лучший ответ Сообщение было отмечено RAFA91 как решение

Решение

Цитата Сообщение от RAFA91 Посмотреть сообщение
Вы не поверите , но когда я тупо прописал в классах A,B,C копировщики , то проблема ушла.
Не поверю. Ты говорил что в catch у тебя ссылки, а их там нет.
1
RAFA91
Заблокирован
06.06.2015, 14:24  [ТС] #17
Вообщем первоначальный код был таким

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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <stdio.h>
#include <conio.h>
 
class Ana
 
{
    int x;
 
public:
 
    Ana(int c); 
 
    Ana(const Ana & rhs) {printf("\nKONSTRUKTOR Ana copy %p %p\n",this,& rhs);}
 
    ~Ana() {}
    
    int ghf() const {return x;}
 
    class A 
    
    { 
    
    public: 
        
        A() {printf("\nKONSTRUKTOR A %p\n",this);}
 
        //A(const A & rhs) {printf("\nKONSTRUKTOR A copy %p %p\n",this,& rhs);}
 
        ~A() {printf("\nDESTRUKTOR A %p\n",this);}
    };
 
    class B : public A 
    
    {
    
    public: 
        
        B() {printf("\nKONSTRUKTOR B %p\n",this);}
 
        //B(const B & rhs) {printf("\nKONSTRUKTOR B copy %p %p\n",this,& rhs);}
 
        ~B() {printf("\nDESTRUKTOR B %p\n",this);}
    };
 
    class C : public B 
    
    {
    
    public: 
        
        C() {printf("\nKONSTRUKTOR C %p\n",this);}
 
        //C(const C & rhs) {printf("\nKONSTRUKTOR C copy %p %p\n",this,& rhs);}
 
        ~C() {printf("\nDESTRUKTOR C %p\n",this);}
    };
};
 
Ana :: Ana(int c) :
 
x(c)
 
{
    if(c == 0) throw B();
 
    if(c < 0) throw A();
 
    if(c > 10) throw C();
}
 
int main()
 
{
    try
 
    {
        Ana s(11);
 
        printf("\n-------- %d\n",s.ghf());
    }
 
 
    catch (Ana :: C )
 
    {
        printf("\n****** c > 10\n");
    }
 
    catch (Ana :: B )
 
    {
        printf("\n****** c == 0\n");
    }
 
 
    catch (Ana :: A )
 
    {
        printf("\n****** c < 0\n");
    }
        
 
        getch();
 
        return 0;
}
теперь разблокировал копировщики

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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <stdio.h>
#include <conio.h>
 
class Ana
 
{
    int x;
 
public:
 
    Ana(int c); 
 
    Ana(const Ana & rhs) {printf("\nKONSTRUKTOR Ana copy %p %p\n",this,& rhs);}
 
    ~Ana() {}
    
    int ghf() const {return x;}
 
    class A 
    
    { 
    
    public: 
        
        A() {printf("\nKONSTRUKTOR A %p\n",this);}
 
        A(const A & rhs) {printf("\nKONSTRUKTOR A copy %p %p\n",this,& rhs);}
 
        ~A() {printf("\nDESTRUKTOR A %p\n",this);}
    };
 
    class B : public A 
    
    {
    
    public: 
        
        B() {printf("\nKONSTRUKTOR B %p\n",this);}
 
        B(const B & rhs) {printf("\nKONSTRUKTOR B copy %p %p\n",this,& rhs);}
 
        ~B() {printf("\nDESTRUKTOR B %p\n",this);}
    };
 
    class C : public B 
    
    {
    
    public: 
        
        C() {printf("\nKONSTRUKTOR C %p\n",this);}
 
        C(const C & rhs) {printf("\nKONSTRUKTOR C copy %p %p\n",this,& rhs);}
 
        ~C() {printf("\nDESTRUKTOR C %p\n",this);}
    };
};
 
Ana :: Ana(int c) :
 
x(c)
 
{
    if(c == 0) throw B();
 
    if(c < 0) throw A();
 
    if(c > 10) throw C();
}
 
int main()
 
{
    try
 
    {
        Ana s(11);
 
        printf("\n-------- %d\n",s.ghf());
    }
 
 
    catch (Ana :: C )
 
    {
        printf("\n****** c > 10\n");
    }
 
    catch (Ana :: B )
 
    {
        printf("\n****** c == 0\n");
    }
 
 
    catch (Ana :: A )
 
    {
        printf("\n****** c < 0\n");
    }
        
 
        getch();
 
        return 0;
}
0
Миниатюры
Исключительные ситуации (повторный вызов деструктора)   Исключительные ситуации (повторный вызов деструктора)  
castaway
Эксперт С++
4929 / 3036 / 453
Регистрация: 10.11.2010
Сообщений: 11,116
Записей в блоге: 10
Завершенные тесты: 1
06.06.2015, 15:10 #18
Лучший ответ Сообщение было отмечено RAFA91 как решение

Решение

Цитата Сообщение от RAFA91 Посмотреть сообщение
у него аж 3 раза вызвался копировщик , а у меня только один раз.
C++
1
        C( const C& _c ):B(_c){ printf("\n C( const C& ) \n"); }
Он из конструктора копирования класса C вызывает конструктор копирования подлежащего класса B, из B вызывает A.
1
RAFA91
Заблокирован
06.06.2015, 15:22  [ТС] #19
Цитата Сообщение от castaway Посмотреть сообщение
Он из конструктора копирования класса C вызывает конструктор копирования подлежащего класса B, из B вызывает A.

точно. не увидел этот момент.

а разве при насследовании копировщики от нижнего уровня до верхнего не вызываются автоматически ?
0
castaway
Эксперт С++
4929 / 3036 / 453
Регистрация: 10.11.2010
Сообщений: 11,116
Записей в блоге: 10
Завершенные тесты: 1
06.06.2015, 15:30 #20
Цитата Сообщение от RAFA91 Посмотреть сообщение
а разве при насследовании копировщики от нижнего уровня до верхнего не вызываются автоматически ?
Нет, не вызываются.
0
06.06.2015, 15:30
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.06.2015, 15:30

Исключительные ситуации
Надо сделать так, чтоб при вводе чарового символа в итовый вектор выводило...

исключительные ситуации
почему не работает?? как надо?? #include&lt;iostream&gt; #include&lt;conio.h&gt;...

Исключительные ситуации
Доброго времени суток. Возникла такая проблема. Никак не могу разобраться с...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru