Не обязательно копировать инструкции try . . . catch, чтобы предотвратить утечку ресурсов. Рассмотрим следующий пример:
void f(vector& v, int s)
{
vector p(s); vector q(s);
// . . .
}
I /f
Это уже лучше. Что еще более важно, это очевидно лучше. Ресурс (в данном случае свободная память) занимается конструктором и освобождается соответствующим деструктором. Теперь мы действительно решили нашу конкретную задачу, связанную с исключениями.
Также вам может показаться, что http://www.isosamara.ru/#!-9001/c13t0 на сайте isosamara.ru и такая тема, как программирование - никак не связаны и даже не тематичны.
Возможно, это и так, но все-таки зайдите на сайт isosamara.ru, чтобы узнать там много интересного про такую тему, как сертификация iso 9001. Что такое сертификация iso 9001, сколько стоит сертификация iso 9001и где заказать сертификацию iso 9001- про это написано на сайте про сертификацию iso 9001. Это важная для многих тема - сертификация iso 9001. Спасибо за информацию сайту сертификацию iso 9001.
Это решение носит универсальный характер; его можно применить ко всем видам ресурсов: конструктор получает ресурсы для объекта, который ими управляет, а соответствующий деструктор их возвращает.
Такой подход лучше всего зарекомендовал себя при работе с блокировками баз данных (database locks), сокетами (sockets) и буферами ввода-вывода (I/O buffers) (эту работу делают объекты класса iostream). Соответствующий принцип обычно формулируется довольно неуклюже: “Получение ресурса есть инициализация” (“Resource Acquisition Is Initialization” — RAII).
Рассмотрим предыдущий пример. Как только мы выйдем из функции f(), будут вызваны деструкторы векторов p и q: поскольку переменные p и q не являются указателями, мы не можем присвоить им новые значения, инструкция return не может предотвратить вызов деструкторов и никакие исключения не генерируются.
Это универсальное правило: когда поток управления покидает область видимости, вызываются деструкторы для каждого полностью созданного объекта и активизированного подобъекта. Объект считается полностью созданным, если его конструктор закончил свою работу.
Исследование всех следствий, вытекающих из этих двух утверждений, может вызвать головную боль. Будем считать просто, что конструкторы и деструкторы вызываются, когда надо и где надо.
В частности, если хотите выделить в области видимости свободную память переменного размера, мы рекомендуем использовать класс vector, а не “голые” операторы new и delete.
Опубликовал katy
April 21 2015 12:41:06 ·
0 Комментариев ·
3019 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.