Читаем Программирование полностью

• Выделение памяти, достаточной для хранения объекта типа T без инициализации.

• Создание объекта типа T в неинициализированной памяти.

• Уничтожение объекта типа T и возвращение памяти в неинициализированное состояние.

• Освобождение неинициализированной памяти, достаточной для хранения объекта типа T без инициализации.

Не удивительно, что класс allocator — то, что нужно для реализации функции vector::reserve(). Начнем с того, что включим в класс vector параметр класса allocator.

template > class vector {

  A alloc;  // используем объект класса allocator для работы

            // с памятью, выделяемой для элементов

  // ...

};

Кроме распределителя памяти, используемого вместо оператора new, остальная часть описания класса vector не отличается от прежнего. Как пользователи класса vector, мы можем игнорировать распределители памяти, пока сами не захотим, чтобы класс vector управлял памятью, выделенной для его элементов, нестандартным образом. Как разработчики класса vector и как студенты, пытающиеся понять фундаментальные проблемы и освоить основные технологии программирования, мы должны понимать, как вектор работает с неинициализированной памятью, и предоставить пользователям правильно сконструированные объекты. Единственный код, который следует изменить, — это функции-члены класса vector, непосредственно работающие с памятью, например функция vector::reserve().

template

void vector::reserve(int newalloc)

{

  if (newalloc<=space) return;     // размер не уменьшается

  T* p = alloc.allocate(newalloc); // выделяем новую память

  for (int i=0; i

                                   // копируем

  for (int i=0; i

  alloc.deallocate(elem,space);    // освобождаем старую память

  elem = p;

  space = newalloc;

}

Мы перемещаем элемент в новый участок памяти, создавая копию в неинициализированной памяти, а затем уничтожая оригинал. Здесь нельзя использовать присваивание, потому что для таких типов, как string, присваивание подразумевает, что целевая область памяти уже проинициализирована.

Имея функции reserve(), vector::push_back(), можно без труда написать следующий код.

template

void vector::push_back(const T& val)

{

  if (space==0) reserve(8);        // начинаем с памяти для 8 элементов

  else if (sz==space) reserve(2*space); // выделяем больше памяти

  alloc.construct(&elem[sz],val);  // добавляем в конец

                                   // значение val

  ++sz;                            // увеличиваем размер

}

Аналогично можно написать функцию vector::resize().

template

void vector::resize(int newsize, T val = T())

{

  reserve(newsize);

  for (int i=sz; i

  // создаем

  for (int i = newsize; i

  // уничтожаем

  sz = newsize;

}

Обратите внимание на то, что, поскольку некоторые типы не имеют конструкторов по умолчанию, мы снова предоставили возможность задавать начальное значение для новых элементов.

Другое новшество — деструктор избыточных элементов при уменьшении вектора. Представьте себе деструктор, превращающий объект определенного типа в простой набор ячеек памяти.

  “Непринужденное обращение с распределителями памяти” — это довольно сложное и хитроумное искусство. Не старайтесь злоупотреблять им, пока не почувствуете, что стали экспертом.

<p id="AutBody_Root356"><strong>19.4. Проверка диапазона и исключения</strong></p>

 Мы проанализировали текущее состояние нашего класса vector и обнаружили (с ужасом?), что в нем не предусмотрена проверка выхода за пределы допустимого диапазона. Реализация оператора operator[] не вызывает затруднений.

template T& vector::operator[](int n)

{

  return elem[n];

}

Рассмотрим следующий пример:

vector v(100);

v[–200] = v[200]; // Ой!

int i;

cin>>i;

v[i] = 999;  // повреждение произвольной ячейки памяти

Этот код компилируется и выполняется, обращаясь к памяти, не принадлежащей нашему объекту класса vector. Это может создать большие неприятности! В реальной программе такой код неприемлем. Попробуем улучшить наш класс vector, чтобы решить эту проблему. Простейший способ — добавить в класс операцию проверки доступа с именем at().

Перейти на страницу:

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных