Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65417
ТЕХНОЛОГИИ ДОСТ... 62337
Имитационное мо... 57995
Реклама
Сейчас на сайте
Гостей: 7
На сайте нет зарегистрированных пользователей

Пользователей: 13,089
новичок: duskob67
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Сравнение двух бинарных деревьев на Turbo Pascal + отчет
Двунаправленный динамический список на Delphi + Блок схемы
Информационная система - транспортный парк на Turbo Pascal (База данных)...

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Управление динамической памятью
Мы уже неоднократно использовали операцию new — настало время разобраться с Некоторыми подробностями. Начнем с самого простого — с создания динамических объектов встроенных типов:
int *pl = new int:



Данный оператор выделяет sizeof (int) байт свободной памяти и записывает адрес этой памяти в переменную-указатель pi. Память никак не инициализируется, даже не обнуляется.
Однако new обладает гораздо более широкими возможностями. Чтобы присвоить значение динамической переменной, необходимо задать его после типа в круглых скобках, например:
int *р2 = new int(100);



В данном случае значение *р2 равно 100. Вообще в скобках может стоять любое выражение, приводимое в данном случае к типу int. Если нужно просто обнулить выделяемую память, можно использовать конструкцию инициализации нулем:
int *рЗ = new int();
С помощью операции new можно создать даже константный динамический объект, например:
const int *рр = new const int(3):



Конечно, константный объект обязан быть проинициализирован, однако ни Visual C++.NET 2003, ни С++ Builder 6 не выдают никаких сообщений об ошибке и даже предупреждений, если константный объект создается без инициализации.
const int *рр = new const int: // явная ошибка не диагностируется
Случайное изменение (например, *рр=0;) динамического константного объекта невозможно — компилятор следит за этим. Не проходит даже явная отмена константности:
const_cast<int>(*pp) = 1;



Компилятор сообщает, что не может преобразовать const int в «чистый» тип int. Его, конечно, можно «обмануть», подменив указатель, например, так:
int *р = const_cast<1nt *>(рр); *р = 0;



Однако, на программистском сленге такой прием получил название «грязный хак» (hack), поэтому без крайней нужды его применять не следует. Да и зачем тогда создавать динамический объект как константный?
Уничтожение объектов и возврат памяти выполняется операцией delete, например:
delete pi;



Естественно, указатель должен быть именно тот, который использовался при создании динамического объекта операцией new. Константный динамический объект уничтожается точно так же:
delete pp:
Сама операция delete не обнуляет указатель, однако она «правильно» работает в том случае, если указатель уже нулевой — она просто ничего не делает. Поэтому проверять указатель на нуль перед уничтожением объекта нет необходимости.
С помощью операции new[] в С++ можно создавать динамические массивы, например:
int *р = new int[100];



При этом выделяется непрерывная область памяти, достаточная для размещения 100 целых чисел типа i nt. Инициализировать такой массив при создании, к сожалению, невозможно. Отсюда следует, что создавать константный динамический массив встроенного типа смысла не имеет — мы не сможем его проинициализи-ровать «легальными» способами1:
const int *рр = new const int[100];



Хотя ни С++ Builder 6, ни Visual C++.NET 2003 никак не реагируют на создание такого массива, тем не менее попытки присвоить значение элементу массива «пресекают на корню». Вероятно, имеет смысл создавать динамический массив с константой-указателем, чтобы именно указатель случайно нельзя было изменить, например:
i/»t * const рр = new i nt [100] ;



Основное преимущество динамического массива состоит в том, что количество элементов можно задавать выражением, вычисляемым во время выполнения программы. Более того, стандарт разрешает создавать динамический массив даже нулевого размера (см. п. п. 5.3.4/7 в [1]), например:
int t = 0: int *pt = new int[t];



Указатель pt получает корректный адрес, отличающийся от любого другого адреса. Таким образом, нет никакой необходимости проверять значение выражения на нуль перед созданием массива.
Программисты тоже любят фотографировать и лучше всего купить фотоаппарат sony по ссылке. Например фотоаппарат Sony Alpha SLT-A77 16-50 kit отлично подойдет для профессиональных снимков. А фотоаппарат Sony CyberShot DSC-W710 Pink является более бюджетным вариантом.
Уничтожение динамического массива осуществляется операцией delete. Например, удалить динамический массив pt следует так:
delete []pt:



Пустые квадратные скобки необходимы. Они говорят компилятору, что указатель адресует массив, а не единичный элемент. Отсутствие скобок не является синтаксической ошибкой (компилятор не выдает никаких сообщений), однако правильность выполнения программы не гарантируется.
Опубликовал Kest October 02 2013 02:41:33 · 0 Комментариев · 2595 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
THttpScan v4.1
Mass Photo Upload
Delphi 7: Для про...
Borland Delphi 8 ...
Черный круг двига...
Разработка распре...
Базы данных в Инт...
Flud Vkontakte.ru
Библия для програ...
Java Server Pages...
Экранная лупа
Atb
SynEdit
Java 2. Наиболее ...
Меню проводника в...
Apollovcl61
Панель поиска
CoolHints2k v1.03
CABfiles
Фундаментальные а...

Топ загрузок
Приложение Клие... 100471
Delphi 7 Enterp... 87456
Converter AMR<-... 20080
GPSS World Stud... 13083
Borland C++Buil... 11929
Borland Delphi ... 8631
Turbo Pascal fo... 7041
Visual Studio 2... 5000
Калькулятор [Ис... 4855
FreeSMS v1.3.1 3543
Случайные статьи
Окно «Параметры Wo...
Можно ли в Интерне...
Лучшие хостинги
Задача кажется сло...
Ага! Алгоритмы
Характерная ситуация
Invalid typecast
Узловое представле...
Файлы устройств и ...
Как клиент DHCP хо...
Обычно при внедрен...
Объекты, интерфейс...
Как определить раз...
Указатели на функц...
Пример применения ...
Блокировка файлов
12.5. Задачи
10.1. Ключ к успех...
универсальной груп...
Аналитические реш...
Подсчет атомов и ч...
PUBLIC, PRIVATE ИЛ...
Модуль CRT. Управл...
Некоторые миры
ПРИЛОЖЕНИЕ 2. Осно...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?