Статья

Статья Свободная Память

Работа добавлена на сайт bukvasha.net: 2015-10-29

Поможем написать учебную работу

Если у вас возникли сложности с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой - мы готовы помочь.

Предоплата всего

от 25%

Подписываем

договор

Выберите тип работы:

Скидка 25% при заказе до 23.6.2025



Свободная Память

Если вы пользовались классом slist, вы могли обнаружить, что ваша программа тратит на заметное время на размещение и освобождение объектов класса slink. Класс slink - это превосходный пример класса, который может значительно выиграть от того, что программист возьмет под контроль управление свободной памятью. Для этого вида объектов идеально подходит оптимизирующий метод. Поскольку каждый slink создается с помощью new и уничтожается с помощью delete членами класса slist, другой способ выделения памяти не представляет никаких проблем.

Если производный класс осуществляет присваивание указателю this, то конструктор его базового класса будет вызываться только после этого присваивания, и значение указателя this в конструкторе базового класса будет тем, которое присвоено конструктором производного класса. Если базовый класс присваивает указателю this, то будет присвоено то значение, которое использует конструктор производного класса.

Например:

#include

struct base { base(); };

struct derived : base { derived(); }

base::base()

{

  cout << "\tbase 1: this=" << int(this) << "\n";

  if (this == 0) this = (base*)27;

  cout << "\tbase 2: this=" << int(this) << "\n";

}

derived::derived()

{

  cout << "\tderived 1: this=" << int(this) << "\n";

  this = (this == 0) ? (derived*)43 : this;

  cout << "\tderived 2: this=" << int(this) << "\n";

}

main()

{

cout << "base b;\n";

base b;

cout << "new base b;\n";

new base;

cout << "derived d;\n";

derived d;

cout << "new derived d;\n";

new derived;

cout << "at the end\n";

}

порождает вывод

base b;

      base 1: this=2147478307

      base 2: this=2147478307

new base;

      base 1: this=0

      base 2: this=27

derived d;

      derived 1: this=2147478306

      base 1: this=2147478306

      base 2: this=2147478306

      derived 1: this=2147478306

new derived;

      derived 1: this=0

      base 1: this=43

      base 2: this=43

      derived 1: this=43

at the end

Если деструктор производного класса осуществляет присваивание указателю this, то будет присвоено то значение, которое встретил деструктор его базового класса. Когда кто-либо делает в конструкторе присваивание указателю this, важно, чтобы присваивание указателю this встречалось на всех путях в конструкторе.

Список литературы

Для подготовки данной работы были использованы материалы с сайта http://www.realcoding.net



1. Реферат Арш
2. Реферат Учет основных средств 22
3. Курсовая на тему Сравнительная характеристика браузеров
4. Контрольная_работа на тему Теоретические основы и технологии начального образования по естествознанию
5. Контрольная работа Правила поведения заложников
6. Реферат на тему The Wasteland Essay Research Paper TS Eliot
7. Реферат на тему Drawing I Essay Research Paper
8. Реферат на тему The Need For Extreme Criminal Justice Reform
9. Контрольная работа Производственная функция
10. Реферат на тему Oedipus Essay Research Paper The Presence of