Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Динамические массивы, Работа з 2,3-мерными массивами 
:(
    Опции темы
stalker1991
Дата 29.1.2012, 00:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 2
Регистрация: 25.9.2009

Репутация: нет
Всего: нет



Доброго времени суток! Нуждаюсь в вашей помощи.
Есть такой код: (идея: 2 и 3-мерный масивы. под оба виделяется память и тут же оба удаляются. Утечки памяти нет, после удаления прога займет в ОЗУ примерно 2,5 мб (как и до запуска)).

Код

.
.
.
int n = 10;
double ***Ar2, **B;
void __fastcall TForm1::Button3Click(TObject *Sender)
{
    Ar2 = new double**[n];
    B = new double *[n];

    for (int k=0; k<n; k++)
    {
        Ar2[k] = new double*[n];
        B[k] = new double[n];
    }
    for (int k=0; k<n; k++)
        for (int j=0; j<n; j++)
        {
            Ar2[k][j] = new double[n];
            B[k][j] = j;
        }

//удаление масивов
    for (int k=0; k<n; k++)
        for (int j=0; j<n; j++)
            delete[] Ar2[k][j];
    for (int k=0; k<n; k++)
    {
        delete[] Ar2[k];
        delete[] B[k];
    }

    delete[] Ar2;
    delete[] B;
}


теперь модифицирую код так, чтобы в один з элементов 3-хмерного масива копировался двухмерный. Тогда в цыклах удаления надо убрать этот 2-мерный масив В, так как при присваивании он уничтожается(?) и оператор delete[] выдает ошыбку. Перед помещением в 3-мерный из него удаляется содержимое для устранения засорения памяти. В таком коде есть утечка памяти.

Код

int n = 10;
double ***Ar2, **B;
void __fastcall TForm1::Button3Click(TObject *Sender)
{
    Ar2 = new double**[n];
    B = new double *[n];

    for (int k=0; k<n; k++)
    {
        Ar2[k] = new double*[n];
        B[k] = new double[n];
    }
    for (int k=0; k<n; k++)
        for (int j=0; j<n; j++)
        {
            Ar2[k][j] = new double[n];
            B[k][j] = j;   //заполнение масива данными
        }

    delete[] Ar2[1];   //удаление содержымого 
    Ar2[1] = B;
//удаление масивов
    for (int k=0; k<n; k++)
        for (int j=0; j<n; j++)
            delete[] Ar2[k][j];
    for (int k=0; k<n; k++)
    {
        delete[] Ar2[k];
//        delete[] B[k];  ******ошыбка доступа к несуществующему элементу*******
    }

    delete[] Ar2;
    delete[] B;
}


Можете подсказать, в чем проблема? во втором случае при каждом нажатии кнопки прога кушает ~500 кб ОЗУ. Вроде бы немного, но этот код - часть цыкла генетического алгоритма, исчислений там очень много, поэтому довольно быстро прога доходит до 2 Гб и вилетает из ошыбкой виделения памяти. (если просто элементам присваивать значения вроде Ar2[1][2][4] = 8, то никаких проблем нет).
И как бить, если надо вместо Ar2[1] = B; написать Ar2[1] = func (параметры), тоесть присвоить одному из элементов значениие функции. которая возвращает указатель на 2-мерный масив? 
PM MAIL   Вверх
586
Дата 29.1.2012, 02:32 (ссылка) |   (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2243
Регистрация: 8.5.2006

Репутация: 57
Всего: 146



Строка "Ar2[1] = B;" копирует указатель, в дальнейшем, память освобождается дважды, в чём и ошибка.
Код
int n = 10;
double ***Ar2, **B;
void __fastcall TForm1::Button1Click(TObject *Sender)
{
    Ar2 = new double**[n];
    B = new double *[n];
    for (int k=0; k<n; k++)
    {
        Ar2[k] = new double*[n];
        B[k] = new double[n];
    }
    for (int k=0; k<n; k++)
        for (int j=0; j<n; j++)
        {
            Ar2[k][j] = new double[n];
            B[k][j] = j;   //заполнение масива данными
        }

    //удаление содержимого
    for(int i=0; i<n; i++)
        delete []Ar2[1][i];
    delete[] Ar2[1];

    //копирование содержимого
    Ar2[1] = new double*[n];
    for(int i=0; i<n; i++)
    {
        Ar2[1][i] = new double[n];
        for(int j=0; j<n; j++)
        {
            Ar2[1][i][j]=B[i][j];
        }
    }

    //удаление массивов
    for (int k=0; k<n; k++)
        for (int j=0; j<n; j++)
            delete[] Ar2[k][j];
    for (int k=0; k<n; k++)
    {
        delete[] Ar2[k];
        delete[] B[k];
    }
    delete[] Ar2;
    delete[] B;
}

PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++ Builder"
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по С++ Builder обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Настоятельно рекомендуем заглянуть в DRKB (Delphi Russian Knowledge Base) - крупнейший в рунете сборник материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Rrader.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C++ Builder | Следующая тема »


 




[ Время генерации скрипта: 0.0611 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.