Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.58/160: Рейтинг темы: голосов - 160, средняя оценка - 4.58
9 / 9 / 1
Регистрация: 17.06.2012
Сообщений: 168

указатели и очистка памяти

23.11.2012, 20:41. Показов 31283. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В отличии от java в с++ память по умолчанию нужно очищать самостоятельно.

Понятно, что если память зарезервированная неким указателем не нужна его следует просто удалить.
но если указатель например р1 ссылается на структуру, мне же нужно присвоить указателю другую структуру того же типа содержащуюся в адресе р2.
Т.е. если я просто присвою указателю р1 который уже содержит структуру адрес новой структуры указателя р2, то старые данные потеряются навсегда но будут занимать место?

Правильно ли я поступлю, если создам новый новый указатель р0, сделаю присвоения р0 = р1; затем delete* р0;
и далее p1 = p2 ?

К слову читал, что в С++ есть сборщики мусора.
Насколько они используются ?
Это экзотика или же стандартная фича?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.11.2012, 20:41
Ответы с готовыми решениями:

Указатели и очистка памяти
Возник интересный вопрос... class Test { int a; }; class Test1 : public Test { int b, c; }; int main() { Test1 *t = new Test1; ...

Очистка памяти
Как правильно очистить память в массиве классов Вот код конструктора, выделяющего память, и деструктора. Выдает ошибку в самом конце...

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

23
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
23.11.2012, 20:45
Цитата Сообщение от ntny Посмотреть сообщение
то старые данные потеряются навсегда но будут занимать место?
Да (если, конечно же, у Вас не "умные" указатели)
Цитата Сообщение от ntny Посмотреть сообщение
Правильно ли я поступлю, если создам новый новый указатель р0, сделаю присвоения р0 = р1; затем delete* р0;
и далее p1 = p2 ?
А не легче
C++
1
delete p1; p1=p2;
Цитата Сообщение от ntny Посмотреть сообщение
К слову читал, что в С++ есть сборщики мусора.
В C++ или в C++/CLI?
0
9 / 9 / 1
Регистрация: 17.06.2012
Сообщений: 168
23.11.2012, 20:45  [ТС]
Хотя delete же освобождает память, но не стирает указатели.
Можно ли так написать
delete* p1;
p1 = p2;


Программа просто негортова в целом для компиляции.
Потому пока не способен проверить все)
0
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
23.11.2012, 20:46
со сборщиками ни разу не имел дело и не очень хочется.
смарт-поинтеры подходят в большинстве случаев. так что перед сборщиками поизучайте смарт-поинтеры
std::auto_ptr
std::shared_ptr
std::unique_ptr
...
их много всяких, если не ограничиваться стандартом и бустом.
0
9 / 9 / 1
Регистрация: 17.06.2012
Сообщений: 168
23.11.2012, 20:50  [ТС]
Croessmah, не слышал о с++/cli

Умные указатели это дополнительные библиотеки?

Добавлено через 3 минуты
DU,
Croessmah,
спасибо)
0
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
23.11.2012, 20:51
все что в пространстве имен std:: - это стандартная библиотеки. точно так же, как std::string, std::vector и т.п.
есть нестандартные, но тех, которые есть в стандарте вполне достаточно.
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
23.11.2012, 20:53
Цитата Сообщение от DU Посмотреть сообщение
но тех, которые есть в стандарте вполне достаточно.
Уточню, что в стандарте C++11.
0
9 / 9 / 1
Регистрация: 17.06.2012
Сообщений: 168
24.11.2012, 21:26  [ТС]
Есть ли в С++ возможность ограничивать использование "вспомогаельных классов"
Т.е. есть собственный класс в собственном пространстве имен.
Для некоторых операций хочу написать подкласс.
Но было бы нежелательно, чтобы этот подкласс можно было вызвать из "клиентского" кода.
В java есть очень удобный пакетный доступ для этих целей.

С аналогичными вопросами на с++ пока не сталкивался.
Кто может посоветовать?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
29.11.2012, 12:15
ntny, пакеты в джаве - по факту аналогия пространствам имём. Используйте из в С++ для этих целей.
 Комментарий модератора 
На каждый вопрос, никак не связанный с другими вашими вопросами, создавайте отдельную тему.
0
What a waste!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
29.11.2012, 12:29
Цитата Сообщение от ntny Посмотреть сообщение
В java есть очень удобный пакетный доступ для этих целей.
В С++ такого нет. Можно описать подкласс в файле реализации, и его описание будет доступно только там. Обычно всё, относящееся к реализации просто складывают в отдельное пространство имён, например detail, impl и т.д..
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
29.11.2012, 12:31
Цитата Сообщение от gray_fox Посмотреть сообщение
В С++ такого нет
Цитата Сообщение от ntny Посмотреть сообщение
В java есть очень удобный пакетный доступ для этих целей.
Только теперь понял, что речь шла об уровне доступа пакета. Тогда да, в плюсах этого действительно нет.
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
29.11.2012, 12:57
Цитата Сообщение от ntny Посмотреть сообщение
В отличии от java в с++ память по умолчанию нужно очищать самостоятельно.
Понятно, что если память зарезервированная неким указателем не нужна его следует просто удалить.
но если указатель например р1 ссылается на структуру, мне же нужно присвоить указателю другую структуру того же типа содержащуюся в адресе р2.
Т.е. если я просто присвою указателю р1 который уже содержит структуру адрес новой структуры указателя р2, то старые данные потеряются навсегда но будут занимать место?
Правильно ли я поступлю, если создам новый новый указатель р0, сделаю присвоения р0 = р1; затем delete* р0;
и далее p1 = p2 ?
К слову читал, что в С++ есть сборщики мусора.
Насколько они используются ?
Это экзотика или же стандартная фича?
Есть массив/список/дерево/любой другой контейнер, а есть указатель на текущий элемент. Их нельзя путать. Если ты выделил
C++
1
p1=new ...
, то p1 - указатель на контейнер, либо служебный указатель самого контейнера на элемент и присваивать ему ничего нельзя до
C++
1
delete p1;
или
C++
1
delete [] p1;
, если же ты хочешь заресайзить массив без потери инфы, то сначала надо выделить память в промежуточный указатель, потом скопировать сохраняемые элементы, потом удалить делитом старый указатель и только потом присвоить ему промежуточный.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
int *p1=new int 10;
...
int *p2;
int *p3;
int *p4;
p2=new int 300;
for (p3=p1+9, p4=p2+9; p3>=p1; --p3, --p4)
{
 *p4=*p3;
}
delete [] p1;
p1=p2;
...
delete [] p1;
. Если же ты присвоил указателю некий адрес, то это только текущий указатель и его нельзя делитить. Хранение и перебор - две разные задачи. И ни кто в здравом уме деструкторы сам не вызывает, это обязанность компилятора, а прописать в деструкторе, что такой указатель надо освободить, а по такому пройти и обнулить встречный может только автор, ни какой сборщик ни когда об этом не догадается.

Добавлено через 4 минуты
Цитата Сообщение от ntny Посмотреть сообщение
р0 = р1; затем delete* р0;
и далее p1 = p2 ?
правильно, но избыточно.
C++
1
2
delete p1;
p1=p2;
.

Добавлено через 4 минуты
Цитата Сообщение от ntny Посмотреть сообщение
Есть ли в С++ возможность ограничивать использование "вспомогаельных классов"
Т.е. есть собственный класс в собственном пространстве имен.
Для некоторых операций хочу написать подкласс.
Но было бы нежелательно, чтобы этот подкласс можно было вызвать из "клиентского" кода.
В java есть очень удобный пакетный доступ для этих целей.
В чём же его удобство? Если класс должен быть закрыт, его можно прописать внутри другого класса и закрыть по protected, или по private, или вообще не выносить в голову, или вынести в отдельную голову и инкладить её не везде, а если пишешь библиотеку, то клиенту можно эту отдельную голову вообще не выдавать, она и будет закрыта, а а пакет вообще не понятно что вообще такое и для чего нужен.
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
29.11.2012, 13:03
Цитата Сообщение от taras atavin Посмотреть сообщение
Если класс должен быть закрыт, его можно прописать внутри другого класса и закрыть по protected, или по private
Если один класс описан внутри другого, то мы логически связываем его с этим другим классом. Но если класс является полностью самостоятельным, мы хотим просто использовать его для реализации функциональности приложения/библиотеки, но наружу давать ему доступ ни к чему, тут подойдёт пакетный уровень доступа.

Цитата Сообщение от taras atavin Посмотреть сообщение
а пакет вообще не понятно что вообще такое
А зачем тогда отвечать на этот вопрос?
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
29.11.2012, 13:06
Цитата Сообщение от silent_1991 Посмотреть сообщение
Если один класс описан внутри другого, то мы логически связываем его с этим другим классом.
А потомок логически не связан с предком?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
29.11.2012, 13:06
taras atavin, а вы признаёте только наследование?
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
29.11.2012, 13:10
Цитата Сообщение от silent_1991 Посмотреть сообщение
Но если класс является полностью самостоятельным, мы хотим просто использовать его для реализации функциональности приложения/библиотеки, но наружу давать ему доступ ни к чему, тут подойдёт пакетный уровень доступа.
Здесь пойдёт отдельная голова для себя и отдельная для всех. В одной голове описываешь те классы, которые должны быть доступны в приладе, а в другой те, которые должны быть доступны только в библиотеке.

Добавлено через 2 минуты
Цитата Сообщение от silent_1991 Посмотреть сообщение
taras atavin, а вы признаёте только наследование?
С чего ты взял? Наследование помянул ТС, читай:
Цитата Сообщение от ntny Посмотреть сообщение
Для некоторых операций хочу написать подкласс.
Но было бы нежелательно, чтобы этот подкласс можно было вызвать из "клиентского" кода.
. Нужны комментарии?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
29.11.2012, 13:12
taras atavin, да, может, это и выход. Но всё же доступ только в пределах пространства имён мне видится более привлекательным и удобным.

Добавлено через 1 минуту
taras atavin, если вы объявите один класс внутри другого как защищённый, то доступ к нему будут иметь только наследники. ТС, как я понял, имеет ввиду, что класс этот можно использовать где угодно в пределах пакета.
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
29.11.2012, 13:15
В пространство имён можно залезть где угодно, это не фактор безопасности, а только страховка от случайного совпадения имён.

Добавлено через 2 минуты
Цитата Сообщение от silent_1991 Посмотреть сообщение
taras atavin, если вы объявите один класс внутри другого как защищённый, то доступ к нему будут иметь только наследники. ТС, как я понял, имеет ввиду, что класс этот можно использовать где угодно в пределах пакета.
У джаванутых приняты специальные классы, оборачиваемые даже вокруг функции, являющейся точкой входа в программу. Так почему бы не перенять этот обычай и не завести специальный оболочечный класс только для управления доступом к другим классам?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
29.11.2012, 13:19
taras atavin, почему обсуждение каких-ибо подобных функций всегда скатывается в безопасность? privat тоже не фактор безопасности, всё это лишь надстройки языка. Про безопасность в случае с пакетным доступом вряд ли идёт речь, речь идёт об удобном предоставлении/непредоставлении доступа разработчику/пользователю соответственно.

Добавлено через 1 минуту
Цитата Сообщение от taras atavin Посмотреть сообщение
У джаванутых приняты специальные классы, оборачиваемые даже вокруг функции, являющейся точкой входа в программу.
Это не у "джаванутых" принято, а в любом полностью ОО-языке. А в вашем примере получается "прощай, проектирование архитектуры!"
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
29.11.2012, 14:23
Цитата Сообщение от silent_1991 Посмотреть сообщение
Это не у "джаванутых" принято, а в любом полностью ОО-языке. А в вашем примере получается "прощай, проектирование архитектуры!"
Это джава то ОО? Хоть на грош? С удалением объекта после единственной операции с ним. Вот плюсы действительно полностью ОО, но не навязывают искусственных классов. Вся программа целиком экземпляром известного ей самой класса по ООП быть вообще не может, так как для неё это будет единственный класс такой абстракции, а она сама - единственный его экземпляр. Она ведь не видит ничего вокруг и не знает, что есть ещё какие то внешние сущности. Вот для пользователя действительно есть класс "приложение". Но этот класс включает в себя одновременно экзел и нидфоспид. А отдельно для экзела класса быть не может и с точки зрения пользователя. Этот класс - искусственная конструкция, примерно как карта, на которой было бы обозначено положение нашей вселенной. Относительно чего его обозначать? Такая суперкарта не нужна и не несёт информации, а вселенную с равным успехом можно обозначить хоть в центре её, хоть возле угла. Или попробуй описать класс "моё сознание". Не сможешь, так как не можешь посмотреть на собственное сознание со стороны.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.11.2012, 14:23
Помогаю со студенческими работами здесь

Очистка памяти
При выполнении программы, память приложения растёт, а она должна быть неизменной. int main() { setlocale(LC_ALL,...

очистка памяти
в данном случае деструктор очистит всё, или нет? #include "base.h" #include <cstdlib> #include <ctime> base::base(int x,int...

очистка памяти
при запуск программы сама собой создаётся точка останова в строке 59. И дальше программа идти не хочет (даже инструментами отладки). //...

Очистка памяти
Цель: Написать программу, которая читает текст из файла и записывает в новый файл те слова, которые содержат буквы, введенные с...

Очистка памяти
Подскажите пожалуйста что не так делаю, создаю массив лейблов: TLabel **Labels; Labels = new TLabel*; for(int i = 0; i < rabot...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru