86 / 7 / 2
Регистрация: 04.06.2010
Сообщений: 80
1

Вызов деструкторов членов класса

08.11.2010, 00:40. Показов 3252. Ответов 10
Метки нет (Все метки)

у меня есть класс поля которого тоже классы...при выходе из конструктора вызывается деструктор для его полей..даже для указателей...что делать?как этого избежать?
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.11.2010, 00:40
Ответы с готовыми решениями:

Вызов метода класса из другого класса
Есть два класса "нижнего уровня" и один "верхнего уровня" Классы "нижнего уровня" имеют методы с...

Вызов членов и объектов с наследника класса
Есть базовый класс и два наследника: class CBase { public: int iNum; ...

Отладчик и вызов деструкторов
Всем привет. Как в отладчике посмотреть, были ли вызваны деструкторы локальных объектов функции?

Наследование - вызов конструкторов и деструкторов
Делаю два класса - предок и потомок: class class_1_type { private: int t; public: ...

10
73 / 73 / 10
Регистрация: 04.12.2008
Сообщений: 458
08.11.2010, 00:59 2
поля-классы представлены у Вас просто как переменные или как указатели (ссылки) ?
0
86 / 7 / 2
Регистрация: 04.06.2010
Сообщений: 80
08.11.2010, 01:00  [ТС] 3
как указатели
0
бжни
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
08.11.2010, 01:01 4
как обявлены поля, как объявлен деструктор
деструкторы для указателей просто так не вызовутся
0
86 / 7 / 2
Регистрация: 04.06.2010
Сообщений: 80
08.11.2010, 01:03  [ТС] 5
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
class cName
{
    MyString* fio;
public:
    cName():fio()
    {
    }
    cName(char* n, char* f, char* nof)
    {
        int l;
        char* fio1=new char[l=(strlen(n)+(strlen(f)+strlen(nof)+3))];
        fio1=strcat(n," ");
        fio1=strcat(fio1,f);
        fio1=strcat(fio1," ");
        fio1=strcat(fio1,nof);
        fio1[l]='\0';
        fio=&MyString(fio1);
    }
 
 
class MyString
{
    char* str;
    int length;
public:
    ~MyString()
    {
        delete[]str;
    }
0
Эксперт С++
2924 / 1273 / 114
Регистрация: 27.05.2008
Сообщений: 3,465
08.11.2010, 12:32 6
Гм. Я бы выразился в том смысле, что приведенный код не просто плохой - он очень плохой. Надеюсь, коллега Alexanches найдет время его поправить. Проблемы, которые я вижу с ходу:
1. Совершенно непонятно, какой из классов владеет памятью, выделяемой под строку. Выделяется память в одном классе, удаляется в совершенно другом.....
2. В конструкторе класса cName переменной fio присваивается адрес временного объекта; и куда будет указывать эта переменная после завершения тела конструктора - даже Б.Г. не знает....

Я бы предложил переделать этот код следующим образом:
1. Четко определить "зоны ответственности" классов. Так, класс MyString должен только хранить строку и предоставлять определенные операции над ней. Он же исключительно отвечает за выделение/удаления необходимой для строки памяти. Класс же cName должен хранить имя как готовый объект класса MyString, при этом внутреннее устройство класса MyString ему совершенно не интересно.
2. Исходя из этого, реализовать в классе MyString:
- конструктор по умолчанию, который должен инициализировать пустую строку;
- конструктор из const char*;
- правильные конструктор копирования и оператор присваивания;
- оператор + для конкатенации строк;
- ну и, возможно, оператор преобразования в const char* для вывода строки функцией типа printf, или же еще лучше дружественный оператор << для вывода в поток.
При этом все выделение и освобождение памяти должен выполнять класс MyString.
3. А класс cName должен просто хранить имя в член-переменной класса MyString, ну и предоставлять какой-то необходимый доступ к ней. Необходимо реализовать:
- конструктор из набора параметров - const char*, как написано - фамилия, имя, отчество.... и т.д.
- возможно, какие-то еще функции....

Во.
0
86 / 7 / 2
Регистрация: 04.06.2010
Сообщений: 80
09.11.2010, 21:56  [ТС] 7
собственно если в cName объект то он удаляется деструктором майстринга с тем же успехом)конструкторы и перегруженные операторы есть просто здесь не приведены...операторы ввода вывода не перегружаю потому что задача для формы..
0
86 / 7 / 2
Регистрация: 04.06.2010
Сообщений: 80
18.11.2010, 00:24  [ТС] 8
заменил
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
        cName(char* n, char* f, char* nof)
        {
                int l;
                char* fio1=new char[l=(strlen(n)+(strlen(f)+strlen(nof)+3))];
                fio1=strcat(n," ");
                fio1=strcat(fio1,f);
                fio1=strcat(fio1," ");
                fio1=strcat(fio1,nof);
                fio1[l]='\0';
                fio=&MyString(fio1);
        }
на 
cName(char* f):fio(f)
{};
где действия приведенные в 1 варианте выполняются вне конструктора...почему то деструктор не вызывается...
0
86 / 7 / 2
Регистрация: 04.06.2010
Сообщений: 80
22.12.2010, 22:03  [ТС] 9
блин о5 та же шляпа..
вызываю функцию..оператор = перегружен при выходе из функции вызывается деструктор...
класс:
C++
1
2
3
4
5
6
class MyString
{
    char* str;
    int length;
public:
...};
вызов:
(name.input(m[first++])
функция:
C++
1
2
3
4
5
6
7
    int input(TextBox^ t)
{char buf[256];
    MyConvert::copyto(buf,t->Text->ToString(),255);
    MyString p(buf);
    this->assign(p);
return length=strlen(str); 
return 0;}
оператор=:
C++
1
2
3
4
5
6
7
8
9
10
11
12
    MyString& operator=(const MyString& st)
    {
        if(str!=st.str)
        {
            length=st.length;
            delete[] str;
            str=new char [st.length];
            strcpy(str,st.str);
            return *this;
        }
        return *this;
    }
0
3935 / 1993 / 720
Регистрация: 29.11.2010
Сообщений: 4,277
23.12.2010, 00:10 10
Рекомендую почитать вдумчиво, что написал CheshireCat. Там, конечно, многабукаф, но вполне доходчиво.

Вообще, постоянно имейте в виду, что все переменные, объявленные в функции, будут уничтожены после выхода из функции.
C++
1
2
3
4
5
6
7
8
9
int input(TextBox^ t) {
  char buf[256];
  MyConvert::copyto(buf,t->Text->ToString(),255);
  MyString p(buf);  // объявленная в функции переменная.
  this->assign(p);
  return length=strlen(str); 
  return 0;   // выход из функции. будет уничтожена переменная p 
                // и вызван деструктор MyString::~MyString(p)
}
Никакой магии. Повторю, все, объявленное в функции будет уничтожено при выходе из функции.
0
86 / 7 / 2
Регистрация: 04.06.2010
Сообщений: 80
23.12.2010, 15:45  [ТС] 11
к сожалению все это прочитал, и уже учел) что объявлено в функции не динамическое удалится, это понятно..к сожалению он(деструктор) удаляет тот объект который создан вне функции..при том он же вызывает эту ф-ю инпут .. то есть он вызвал его удалили)
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
23.12.2010, 15:45
Помогаю со студенческими работами здесь

Вызов конструкторов/деструкторов при наследовании
Объясните пожалуйста, как получается вывод на экран 2531 #include &lt;iostream&gt; class A {...

Непонятный вызов Деструкторов при создании списка
Непонятный вызов Деструкторов при создании списка. #include &lt;iostream&gt; #include &lt;list&gt;...

Вызов лишних конструкторов и деструкторов в std::vector
почему вызывает лишние конструкторы и вообще делает не то, что ожидаешь class S { public: int...

Создание и разрушение объектов класса, исследование вызовов конструкторов и деструкторов
Здравствуйте! Проверте пожалуйста код и подскажите мои ошибки. Согласно теме необходимо разобрать...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru