Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > C/C++: Для новичков > Расширение памяти


Автор: shinoby 9.3.2008, 19:39
Предположим есть часть кода:
Код

#include<iostream.h>
class kl{
int a;
float b;
public:
void dan(int c,float d){
a*=c; b+=d;}
}
void main(){
int ind;
cin>>ind;   //Пусть ввели ind=5
kl *mas=new kl [ind];
//И т.д.
}

Я могу в дальнейшей части кода увеличить объем памяти выделенной под 5 объектов класса "а", расширить до 10 объектов? Как это сделать?

Автор: bsa 9.3.2008, 19:52
http://forum.vingrad.ru/forum/topic-189118/kw-динамический-массив-array-vector-faq.html

Автор: comcon1 10.3.2008, 10:58
В общем, от тебя отвязались. И, кстати, правильно сделали. Вот код самостоятельного перевыделения памяти под массив:

Код

#include <cstdlib> // Для malloc() и free()
// ...
Tp *elements = (Tp *) malloc ( sizeof(Tp) * n1 );
// ...
elements = (Tp *)realloc( elements, sizeof(Tp) * n2 );
// ...
free(elements);


Однако, если вы все правильно понимаете, использование операторов new[] и delete[] намного предпочтительнее. Если не понимаете почему - представьте, что Tp - класс, и ему треба обязательно вызывать конструктор и деструктор.

vector работает быстро. Если вы по тем или иным причинам не удовлетворены его работой, то это прямая дорога к написанию собственных new, delete, new[], delete[].Но, по-моему, это геморрой с такой орех, что лучше юзать vector)))

Автор: shinoby 10.3.2008, 18:05
Цитата(comcon1 @ 10.3.2008,  10:58)
В общем, от тебя отвязались.

Отвязались - это громко сказано. Ссылка указывает на вполне достойный, внимания, материал. Я уже обратил внимание на вариант использования malloc и realloc как средство переопределения (расширения, в моем случае) памяти и за это спасибо bsa.
Меня же, на тот момент, интересовала такая возможность относительно new и delete, т.к. на данный момент, до использования std::vector<int> и т.п. я еще не дорос.

Самообразование, знаете ли - дело тяжелое. smile 

Автор: bsa 11.3.2008, 00:16
Цитата(shinoby @ 10.3.2008,  18:05)
Меня же, на тот момент, интересовала такая возможность относительно new и delete, т.к. на данный момент, до использования std::vector<int> и т.п. я еще не дорос.

у new/delete нет возможности расширения. Только с помощью перевыделения памяти и копирования.
Наиболее подходящий вариант именно вектор. Тем более, что в статье я приводил примеры абсолютно идентичные по результату, поэтому, думаю, переключиться на вектор будет довольно просто. А за ним уже и find, list, sort и пр. вкусняшки будут легко освоены.

Автор: comcon1 11.3.2008, 18:56
не хочешь юзать вектор - заводи массив указателей, при чем с помощью malloc, realloc, а вот классы инициализируем с помощью new/delete. Но хочу сказать, что такой код очень уязвим:
Код

Tp **array = (Tp**) malloc(sizeof(Tp*)*n1);
for (int i=0; i<n1; ++i) {
 array[i] = new Tp();
}
// ...
array = (Tp**) realloc(sizeof(Tp*)*n2);
for (int i=n1; i<n2; ++i) {
 array[i] = new Tp();
}
// ..
for (int i=0; i<n2; ++i) {
 delete Tp[i];
}
free(Tp);

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)