С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
3 / 3 / 0
Регистрация: 07.10.2018
Сообщений: 59

Динамическое выделение памяти

05.04.2020, 20:57. Показов 1557. Ответов 9

Студворк — интернет-сервис помощи студентам
Есть функция:
C++
1
2
3
4
5
6
7
 
char* function(unsigned int size)
{
    char* ret =new char[size];
    //какие-то вычисления
    return ret;
}
Проблема состоит в том, что выделенный размер
C++
1
char* ret;
не равен значению переменной
C++
1
size
А больше и из-за этого после нужных данных в переменной остался всякий мусор и вывод в консоль через cout выводит не только данные, но и лишний мусор. Также через точку останова можно это увидеть. В чем может быть проблема?


Компилятор: Visual Studio 2019
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.04.2020, 20:57
Ответы с готовыми решениями:

Как использовать динамическое выделение памяти для новых массивов фиксированного размера?
как использовать динамическое выделение памяти для новых массивов фиксированного размера?

Выделение памяти
MyClass& DXI =* new MyClass(); Это корректный код для выделения памяти, чтобы к переменной можно было обращаться не по ссылке? delete...

Распределение памяти. Динамическое выделение памяти
an-1 an-2 ... a2

9
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
05.04.2020, 22:54
А может код покажете?

Вангую, кто-то забыл терминирующий ноль.
0
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
07.04.2020, 04:01
Цитата Сообщение от Dragon_game Посмотреть сообщение
В чем может быть проблема?
В том, что кто-то не прочитал как работать с sizeof и применяет его не для того, для чего он предназначен?

Добавлено через 1 минуту
Или в том, что кто-то забыл терминирующий ноль.

Предыдущей Ванги вариант.
Астрал штормит сегодня, не понять толком.
0
3 / 3 / 0
Регистрация: 07.10.2018
Сообщений: 59
07.04.2020, 14:37  [ТС]
Вот функция:

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
char* swipe(char *s, int s1, int e1, int s2, int e2, unsigned int size)
{
 
       char* ret=new char[size];
    int n = 0;
    int p = 0;
    while (p < s1)
    {
        ret[n] = s[p];
        p++;
        n++;
    } 
    p = s2;
    while (p < e2)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    p = e1;
    while (p < s2)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    p = s1;
    while (p < e1)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    p = e2;
    while (p < size-1)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    return ret;
 
}
Цитата Сообщение от DrOffset Посмотреть сообщение
В том, что кто-то не прочитал как работать с sizeof и применяет его не для того, для чего он предназначен?
sizeof здесь вообще не причем. Даже если константой объявлять, то все равно выделенный размер больше чем нужно
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
07.04.2020, 15:31
Цитата Сообщение от Dragon_game Посмотреть сообщение
Вот функция
И что мы должны из этого понять?
Что это за s, s1, e1, s2, e2, size?
Опять к пророкам идти?

Будьте уж добры показать не только функцию, но и её использование.
Предоставьте всё необходимое для воспроизведения проблемы.
0
3 / 3 / 0
Регистрация: 07.10.2018
Сообщений: 59
07.04.2020, 15:39  [ТС]
Данная функция меняет местами 2 слова в массиве s
C++
1
2
3
4
5
6
char* s //начальный массив
int s1   // начало первого слова
int e1   // конец первого слова
int s2  // начало второго слова
int e2   // конец второго слова
unsigned int size // размер массива s
Функция работает как надо, но только вместе с тем возвращает всякий мусор после нужной информации
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
07.04.2020, 15:42
Dragon_game, программу покажи, чтобы можно было взять и посмотреть на нее, а не ходить каждый раз в астрал. Почему постоянно надо всё вытягивать!
0
3 / 3 / 0
Регистрация: 07.10.2018
Сообщений: 59
07.04.2020, 15:53  [ТС]
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
#include <windows.h>
#include <iostream>
#include <string>
 
using namespace std;
char* swipe(char* s, int s1, int e1, int s2, int e2, unsigned int size);
char* str;
 
int main()
{
    string str2;
    getline(cin, str2);
    str = (char*)str2.c_str();
 
    cout << swipe(str, 0, 1, 2, 3, str2.size()) << endl;
 
    system("pause");
    return 0;
 
}
 
 
char* swipe(char* s, int s1, int e1, int s2, int e2, unsigned int size)
{
 
    char* ret = new char[size];
    int n = 0;
    int p = 0;
    while (p < s1)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    p = s2;
    while (p < e2)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    p = e1;
    while (p < s2)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    p = s1;
    while (p < e1)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    p = e2;
    while (p < size)
    {
        ret[n] = s[p];
        p++;
        n++;
    }
    return (char*)ret;
 
}
В картинке можно видеть результат работы программы. Числа 1 и 3 поменяны местами, а также можно увидеть тот мусор, что образуется при динамическом выделении
Миниатюры
Динамическое выделение памяти  
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
07.04.2020, 16:02
Лучший ответ Сообщение было отмечено Dragon_game как решение

Решение

C++
1
2
3
4
char* ret = new char[size + 1];
//...
ret[size] = '\0';
return (char*)ret;
1
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
07.04.2020, 16:33
Цитата Сообщение от Dragon_game Посмотреть сообщение
sizeof здесь вообще не причем.
Тем не менее - это одна из самых частых причин проблем у новичков с похожими на ваши симптомами
А код надо сразу показывать, максимально весь. Чтобы людям, которые вам помочь хотят, не приходилось гадать, что вы в итоге все-таки забыли терминирующий ноль, а не решили получить размер массива через sizeof от указателя.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.04.2020, 16:33
Помогаю со студенческими работами здесь

Динамическое выделение памяти
Имеется: #define Index 1000 typedef int BaseType; typedef BaseType TMemList; typedef unsigned ptrel; typedef struct List...

Динамическое выделение памяти
Доброго времени! Прошу помощи, программа не работает. До момента сдвига главной диагонали все отлично, но как только доходит до цикла ...

Динамическое выделение памяти
Здраствуйте. Собственно сам код и вопрос: почему могу свободно выходить за границы массива? Для чего тогда размерность указывается......

Динамическое выделение памяти
есть код: int u = 0; char* mstrcat(char *str1, char *str2) { u = sizeof(str1); // *str1 = new char; char *res = str1; ...

Динамическое выделение памяти
Почему распечатка матрицы Matr1 в f2 дает матрицу из ед., а в f1 матрицу из нулей? Ведь адрес первого эл. массива Matr2 сохранен в...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru