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

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

06.10.2015, 15:05. Показов 1126. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Пользователь вводит числа, которые поступают в массив. Длина массива неизвестна, а использовать большие массивы запрещено. Вопрос, можно ли освободить память в цикле так, чтобы не удалялся один из двух одинаковых указателей(ссылаются на один динамический массив) или как-нибудь заставить работать следующий код? Ошибок не нашел, но срабатывает точка останова (системная).
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
#include <iostream>
 
using namespace std;
 
void Move(int * mass1, int * mass2, int length)
{
    mass1 = new int[length];
    for (auto i = 0;i < length;i++)
        mass1[i] = mass2[i];
}
 
int main()
{
    setlocale(LC_CTYPE, "rus");
    int cnt = 0, buffer;
    auto mass1 = new int[1];
    int * mass2 = nullptr;
    int * result = nullptr;
    cout << "Вводите числа: "<< endl;
    do
    {
        cin >> buffer;
        cnt++;
        mass2 = new int[cnt];
        mass2[cnt - 1] = buffer;
        for (auto i = 0;i < cnt;i++)
            mass2[i] = mass1[i];
        delete[]mass1;
        Move(mass1,mass2,cnt);
        delete[]mass2;
    } while (buffer >= 0);
    for (auto i = 0;i < cnt - 1;i++)
    {
        cout << mass1[i];
    }
    system("pause");
    return 0;
}
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
06.10.2015, 15:05
Ответы с готовыми решениями:

Объясните правила работы с delete с указателями и массивами (корректное освобождение выделенной памяти)
Указатель содержал ссылку на динамический массив. Массив удалил. Имеет ли смысл применять delete на...

Массив, освобождение памяти
что я сделал не так? #include &quot;stdafx.h&quot; #include &lt;conio.h&gt; #include &lt;stdio.h&gt; #include...

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

Освобождение памяти, выделенной под массив
Выделяю память под массив: int (*array_1) = new int; как освободить то, что выделил? ...

3
Модератор
Эксперт С++
13674 / 10885 / 6463
Регистрация: 18.12.2011
Сообщений: 29,045
06.10.2015, 15:22 2
Лучший ответ Сообщение было отмечено Deather как решение

Решение

C++
1
2
3
4
5
6
void Move(int ** mass1, int * mass2, int length)
{
    *mass1 = new int[length];
    for (auto i = 0;i < length;i++)
        (*mass1)[i] = mass2[i];
}
C++
1
 Move(&mass1,mass2,cnt);
1
22 / 22 / 16
Регистрация: 04.06.2015
Сообщений: 126
06.10.2015, 15:33 3
Deather, а как определяется конец ввода?
0
183 / 181 / 66
Регистрация: 15.02.2015
Сообщений: 515
06.10.2015, 16:01 4
Пытливый Ум, судя по "while (buffer >= 0);" вводом отрицательного числа
0
06.10.2015, 16:01
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.10.2015, 16:01
Помогаю со студенческими работами здесь

Освобождение памяти, выделенной на динамический массив структур
Есть динамический массив структур. Как я понимаю, delete A не производит полной очистки памяти в...

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

Массив указателей на список типа очередь - Освобождение памяти
Я выделял память так m=(SP*)malloc(MAX*sizeof(SP)); , т.е. сделал массив указателей на список...

Освобождение вектора с указателями
Допустим есть структура Node и естьQVector&lt;Node *&gt; m_treeStates вектор указателей на эту...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru