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

Корректное удаление двумерного динамического массива

04.11.2016, 10:59. Показов 4286. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
В программе имеется двумерный динамический массив. Особенность его в том, что часть строк имеет больше столбцов, чем другие. Как освободить память в таком случае?
Конструкция, подобная
C++
1
2
3
4
5
for (int i = 0; i < 10; i++)
{
  delete [] arr[i];
}
delete [] arr;
приводит к зависанию программы (на сколько я понял, можно залезть в недоступную область памяти)

Часть кода следующая:
C++
1
2
3
4
5
6
7
8
9
10
11
    double **Store=new double*[4];
    double *xcv = new double[itsNx+1];
    double *ycv = new double[itsNy+1];
 
    double *dx = new double[itsNXzone];
    double *dy = new double[itsNYzone];
/*заполнение массивов xcv, ycv, dx, dy*/
    Store[0] = xcv;
    Store[1] = ycv;
    Store[2] = dx;
    Store[3] = dy;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.11.2016, 10:59
Ответы с готовыми решениями:

Правильное удаление динамического двумерного массива
Доброго времени суток форумчани. Ну в общем перейду сразу к делу. О себе: сам пишу на JAVA (android),решил взяться за С++,разбираюсь с...

Удаление двумерного динамического массива из памяти
Допустим дан двумерный динамический массив (созданный с помощью new). Как правильно удалить его из памяти? У меня есть три варианта: ...

Удаление двумерного динамического массива (матрицы)
Вот так я создаю двумерный динамический массив. bool **gameFieldArray; gameFieldArray = new bool*; for (int i = 0; i &lt; height;...

6
 Аватар для shilko2013
257 / 234 / 185
Регистрация: 02.04.2016
Сообщений: 898
04.11.2016, 11:10
Лучший ответ Сообщение было отмечено Dmitry12345 как решение

Решение

По-моему, 5ая строка не нужна просто.

Добавлено через 5 минут
Мб лучше заменить 2-11 строки на
C++
1
Store[0] = new double[itsNx+1];
И тп. Место сэкономите и с освобождением проблем не будет.
А в вашем примере нужно
C++
1
delete xcv;
И тд делать.
В конце уже
C++
1
delete [] Store;
1
0 / 0 / 1
Регистрация: 12.09.2015
Сообщений: 37
04.11.2016, 11:11  [ТС]
Почему? Мне нужны dx, dy.
0
 Аватар для shilko2013
257 / 234 / 185
Регистрация: 02.04.2016
Сообщений: 898
04.11.2016, 11:22
Dmitry12345, ну раз нужны используйте, а потом очищайте память от них.
C++
1
delete dx;
0
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12933 / 6801 / 1820
Регистрация: 18.10.2014
Сообщений: 17,214
04.11.2016, 11:45
Цитата Сообщение от Dmitry12345 Посмотреть сообщение
В программе имеется двумерный динамический массив. Особенность его в том, что часть строк имеет больше столбцов, чем другие. Как освободить память в таком случае?
Как обычно. То, что строки имеют разный размер, ни на что не влияет.

Цитата Сообщение от Dmitry12345 Посмотреть сообщение
Конструкция, подобная
C++
1
2
3
4
5
for (int i = 0; i < 10; i++)
{
  delete [] arr[i];
}
delete [] arr;
приводит к зависанию программы (на сколько я понял, можно залезть в недоступную область памяти)
Конструкция выглядит нормально. Поэтому если у вас возникает какое-то "зависание", то виновата отнюдь не конструкция. А уж что именно у вас там происходит - нам отсюда не видно. Приводите реальный код, а не "подобные конструкции".
2
0 / 0 / 1
Регистрация: 12.09.2015
Сообщений: 37
04.11.2016, 19:39  [ТС]
Привожу весь код программы.

Header.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#pragma once
#include <iostream>
 
using namespace std;
 
class NonUniformGrid
{
public:
    double **Grid();
    void SetitsNxiNyi(int *Nxi, int *Nyi, int Nx, int Ny);
    void SetitsLxiLyi(double *Lxi, double *Lyi, double Lx, double Ly);
    void SetitsNXYzone(int NXzone, int NYzone);
 
private:
    int itsNXzone, itsNYzone;
    int *itsNxi, *itsNyi, itsNx, itsNy;
    double *itsLxi, *itsLyi, itsLx, itsLy;
};
Source1.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#include "Header.h"
 
void NonUniformGrid::SetitsNxiNyi(int *Nxi, int *Nyi, int Nx, int Ny)
{
    itsNxi = Nxi;
    itsNyi = Nyi;
    itsNx = Nx;
    itsNy = Ny;
}
 
void NonUniformGrid::SetitsLxiLyi(double *Lxi, double *Lyi, double Lx, double Ly)
{
    itsLxi = Lxi;
    itsLyi = Lyi;
    itsLx = Lx;
    itsLy = Ly;
}
 
void NonUniformGrid::SetitsNXYzone(int NXzone, int NYzone)
{
    itsNXzone = NXzone;
    itsNYzone = NYzone;
}
 
double ** NonUniformGrid::Grid()
{
    
    double **Store = new double*[4];
    double *xcv = new double[itsNx + 1];
    double *ycv = new double[itsNy + 1];
 
    int i, j, k;
 
    double *dx = new double[itsNXzone];
    double *dy = new double[itsNYzone];
    // массив шагов по X
    for (int i = 0; i < itsNXzone; i++)
        if (i != 0 && i != itsNXzone - 1)
        {
            dx[i] = itsLxi[i] / itsNxi[i];
        }
        else
            dx[i] = itsLxi[i] / (itsNxi[i] - 0.5);
    // массив шагов по Y
    for (int i = 0; i < itsNYzone; i++)
        if (i != 0 && i != itsNYzone - 1)
        {
            dy[i] = itsLyi[i] / itsNyi[i];
        }
        else
            dy[i] = itsLyi[i] / (itsNyi[i] - 0.5);
    // определение координат граней контрольных объемов
    xcv[0] = 0;
    ycv[0] = 0;
    xcv[itsNx] = itsLx;
    ycv[itsNy] = itsLy;
    //Ox
    k = 1;
 
    for (j = 0; j < itsNXzone; j++)
    {
        for (i = 1;; i++)
        {
            if (i != itsNxi[j] + 1 && k != itsNx)
            {
 
                if (k == 1 || k == itsNx)
                {
                    xcv[k] = xcv[k - 1] + (dx[j] / 2);
                }
                else
                {
                    xcv[k] = xcv[k - 1] + dx[j];
                }
                k++;
            }
            else
                break;
        }
    }
    //Oy
    k = 1;
 
    for (j = 0; j < itsNYzone; j++)
    {
        for (i = 1;; i++)
        {
            if (i != itsNyi[j] + 1 && k != itsNy)
            {
 
                if (k == 1 || k == itsNy)
                {
                    ycv[k] = ycv[k - 1] + (dy[j] / 2);
                }
                else
                {
                    ycv[k] = ycv[k - 1] + dy[j];
                }
                k++;
            }
            else
                break;
        }
    }
    
    Store[0] = xcv;
    Store[1] = ycv;
    Store[2] = dx;
    Store[3] = dy;
    
    return Store;
}
Source.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#include "Header.h"
#include <iostream>
 
using namespace std;
 
int main()
{
 
    NonUniformGrid Object;
    int nxi[3] = { 6,3,5 };
    int nyi[3] = { 5,3,4 };
    double lxi[3] = { 2,1,3 };
    double lyi[3] = { 2,1,3 };
    double lx, ly;
    int nx, ny, nxzone, nyzone;
    double **mass;
 
    lx = 6;
    ly = 6;
    nx = 14;
    ny = 12;
    nxzone = 3;
    nyzone = 3;
 
    Object.SetitsLxiLyi(lxi, lyi, lx, ly);
    Object.SetitsNxiNyi(nxi, nyi, nx, ny);
    Object.SetitsNXYzone(nxzone, nyzone);
    mass = Object.Grid();
 
    for (int i = 0; i < nx + 1; i++)
        cout << mass[0][i] << endl;
 
    for (int i = 0; i < ny + 1; i++)
        cout << mass[1][i] << endl;
 
    
        for (int i = 0; i < nx+1; i++)
             {
                 delete [] mass[i];
             }
 
    delete[]mass;
    mass = 0;
 
    system("pause");
    return 0;
}
0
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12933 / 6801 / 1820
Регистрация: 18.10.2014
Сообщений: 17,214
04.11.2016, 21:01
Лучший ответ Сообщение было отмечено Dmitry12345 как решение

Решение

Цитата Сообщение от Dmitry12345 Посмотреть сообщение
Привожу весь код программы.
Ну так у вас в коде освобождения массива какая-то ерунда написана.

Ваша функция Grid() создает некий двухмерный массив, у котрого ровно 4 строки - от строки 0 до строки 3 (а сами строки могут иметь разную длину). Пока все нормально.

А потом вы вдруг ни с того ни с сего начинаете осовобождать строки этого массива по индексам от 0 до nx. При этом nx равно 14. То есть вы пытаетесь освободить 15 строк. Откуда вдруг взялось 15 и что одно тут делает - не ясно. У вас в массиве ровно 4 строки, а не 15.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.11.2016, 21:01
Помогаю со студенческими работами здесь

Удаление двумерного динамического массива символов
Программа разбивает строку на слова и записывает каждое слово по отдельности в двумерный динамический массив, чтоб потом сравнить. Когда в...

Удаление двумерного динамического массива MSVS
Здравия желаю. При работе с двумерными динамическими массивами столкнулся со странной ошибкой. Если попытаться удалять массив...

Удаление колонки (столбца) из динамического двумерного массива
Сколько ни пытался, не смог понять/придумать как удалить столбец. Строка удаляется элементарно, но как это сделать со столбцом? 30 строка. ...

Правильное удаление двумерного динамического массива ( нужен ли delete[] array )
В одном из постов форума Увидев код одного из участников форума: Я пришел в замешательство, когда мне сказали, что delete arr после...

Не корректное выполнение сортировки двумерного массива
Приветствую всех. Помогите найти и исправить причину не корректной работы программы. Примечание: я еще новичок и решаю задачки на самом...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru