С Новым годом! Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
1 / 1 / 0
Регистрация: 08.05.2013
Сообщений: 23
1

Ошибка при попытке очистить выделенную память

13.10.2013, 19:22. Показов 1571. Ответов 5
Метки нет (Все метки)

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
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
#include <stdio.h>
#include <string.h>
 
#define MAX_WORDS   10
#define MAX_LENGTH  20
 
int ReadWords(char *pWords[]);
void PrintWords(char *pWords[], int counter);
void SortWords(char *pWords[], int counter);
void FreeMemory(char *pWords[], int counter);
 
int main()
{
    char *pWords[MAX_WORDS] = {NULL};
    int wordsCounter;
 
    if ((wordsCounter = ReadWords(pWords)) == -1)
    {
        printf("Failed allocation memory\n");
        return -1;
    }
 
    printf("\nUnsorted list:\n");
    PrintWords(pWords, wordsCounter);
 
    SortWords(pWords, wordsCounter);
    printf("Sorted list:\n");
    PrintWords(pWords, wordsCounter);
 
    FreeMemory(pWords, wordsCounter);
    getch();
    return 0;
}
 
void SortWords(char *pWords[], int counter)
{
    int index;
    char *tempWord;
    char isSorted;
 
    isSorted = 0;
    while (isSorted == 0)
    {
        isSorted = 1;
        for (index = 0; index < (counter - 1); index++)
            if (strcmp(pWords[index], pWords[index + 1]) > 0)
            {
                isSorted = 0;
                tempWord = pWords[index + 1];
                pWords[index + 1] = pWords[index];
                pWords[index] = tempWord;
            }
    }
}
 
int ReadWords(char *pWords[])
{
    int charCounter;
    int index = 0;
    int ch;
    char *tempPointer = NULL;
    char word[MAX_LENGTH + 1];
 
    do
    {
        tempPointer = word;
        charCounter = 0;
        while (((ch = getchar()) != '\n') && (ch != EOF))
            if (charCounter++ < MAX_LENGTH)
                *tempPointer++ = ch;
        *tempPointer = '\0';
 
        if (charCounter > MAX_LENGTH)
            continue;
        else if (charCounter != 0)
        {
            tempPointer = NULL;
            tempPointer = (char *)malloc(strlen(word));
            if (tempPointer == NULL)
            {
                index = -1;
                break;
            }   
            strcpy(tempPointer, word);
            pWords[index++] = tempPointer;
        }
    } while ((charCounter != 0) && (index < MAX_WORDS));
 
    return index;
}
 
void PrintWords(char *pWords[], int counter)
{
    while (counter-- > 0)
        printf("%s\n", *pWords++);
    putchar('\n');
}
 
void FreeMemory(char *pWords[], int counter)
{
    while (counter-- > 0)
        free(pWords++);
}
Программа сортирует строки(не более 10-ти) длиной не более 20 символов. В конце, после сортировки и вывода на экран, программа при попытке выполнить функцию free(pWords) выводит окно с сообщением:
"Debug Assertion Failed!
....................................
Expression: _CrtIsValidHeapPointer(pUserData)
................................................................"
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.10.2013, 19:22
Ответы с готовыми решениями:

При попытке очистить память программа память программа падает
#include &lt;stdio.h&gt; #include &lt;string.h&gt; #include &lt;stdlib.h&gt; struct string { char str; ...

Ошибка передачи указателя на выделенную память
Ситуация следующая, при первом добавлении элемента все хорошо, как только добавляю второй элемент...

Ошибка при попытке очистить дерево дважды или попытке очистить и заново заполнить
Привет, нужно написать программу с деревьями ( VS, формы) однако возникли проблемы: есть функции ...

Очистить динамическую память, выделенную под член структуры
Объявление и инициализация объекта: pupil B = Constructor(&quot;MyName&quot;, 18, 50); Сама структура:...

5
202 / 200 / 65
Регистрация: 06.10.2013
Сообщений: 552
13.10.2013, 19:51 2
C
1
2
while (counter-- > 0)
        free(pWords[counter]);
1
1 / 1 / 0
Регистрация: 08.05.2013
Сообщений: 23
13.10.2013, 21:37  [ТС] 3
Цитата Сообщение от XZentus Посмотреть сообщение
C
1
2
while (counter-- > 0)
        free(pWords[counter]);
И? Да, я сам писал код. И мне действительно кажется, что всё правильно написано, но похоже что нет, и я не знаю, в чем тут ошибка

Добавлено через 1 час 26 минут
Цитата Сообщение от XZentus Посмотреть сообщение
C
1
2
while (counter-- > 0)
        free(pWords[counter]);
Опять ошибка. Только теперь: "HEAP CORRUPTION DETECTED: after Normal block (#58) at 0x00344BF0. CRT detected that the application wrote to memory after end of heap buffer"
0
544 / 93 / 49
Регистрация: 16.12.2011
Сообщений: 317
14.10.2013, 00:45 4
qwe321, у вас похоже не в функции очистки проблема. Вы код постепенно отлаживали, или написали все а потом начали смотреть: где же ошибка?
0
419 / 418 / 167
Регистрация: 28.11.2010
Сообщений: 1,183
14.10.2013, 00:51 5
C
1
tempPointer = (char *) malloc(strlen(word)+1);
1
1 / 1 / 0
Регистрация: 08.05.2013
Сообщений: 23
14.10.2013, 12:07  [ТС] 6
Цитата Сообщение от VEINHORN Посмотреть сообщение
qwe321, у вас похоже не в функции очистки проблема. Вы код постепенно отлаживали, или написали все а потом начали смотреть: где же ошибка?
Функцию очистки в самом конце добавил)

Добавлено через 46 секунд
Цитата Сообщение от vua72 Посмотреть сообщение
C
1
tempPointer = (char *) malloc(strlen(word)+1);
Неа, то же самое =(

Добавлено через 2 минуты
Цитата Сообщение от XZentus Посмотреть сообщение
C
1
2
while (counter-- > 0)
        free(pWords[counter]);
Цитата Сообщение от vua72 Посмотреть сообщение
C
1
tempPointer = (char *) malloc(strlen(word)+1);
Комбинация дала нужный результат =) спс
0
14.10.2013, 12:07
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.10.2013, 12:07
Помогаю со студенческими работами здесь

Почему при записи в не выделенную память программа не падает?
Разбираюсь с malloc(), делаю так: #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;string.h&gt; ...

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

Попытка чтения или записи в защищенную память при попытке воспроизвести поток
что не так? при попытке воспроизвести поток на последней строчке возникает исключение...

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Как программировать под HCL Notes и создавать свои продукты на ее основе
InfoMaster 11.01.2025
HCL Notes (ранее известный как IBM Notes и Lotus Notes) представляет собой мощную платформу для разработки корпоративных приложений, которая сочетает в себе функции электронной почты, календаря,. . .
Как работать с SVN (Subversion)
InfoMaster 11.01.2025
Введение Система контроля версий является неотъемлемой частью современного процесса разработки программного обеспечения. Она обеспечивает управление изменениями в коде, позволяет отслеживать. . .
Использование GraphQL в JavaScript
InfoMaster 11.01.2025
Введение в GraphQL и его преимущества В современной разработке веб-приложений эффективный обмен данными между клиентом и сервером играет ключевую роль. GraphQL представляет собой язык запросов и. . .
Администрирован­­­­ие Git, продвинутые техники работы с Git
InfoMaster 11.01.2025
Основы управления репозиторием Эффективное управление Git-репозиторием требует глубокого понимания механизмов контроля доступа и инструментов администрирования. Рассмотрим ключевые аспекты. . .
Что такое HCL Notes и как с ним работать
InfoMaster 10.01.2025
HCL Notes (ранее известный как IBM Notes и Lotus Notes) представляет собой комплексную платформу для совместной работы и обмена информацией в корпоративной среде. Это многофункциональное решение,. . .
Как работать с Git из Windows и Visual Studio
InfoMaster 10.01.2025
Работа с Git в Windows Работа с Git в операционной системе Windows может быть осуществлена с помощью различных инструментов, каждый из которых обладает своими уникальными возможностями и. . .
Аналог оператора switch case в Python
InfoMaster 10.01.2025
Оператор switch case используется в программировании для выбора одного из нескольких вариантов исполнения кода. Однако в языке Python этот оператор отсутствует. Понимание аналогов switch case в. . .
Отличия абстрактного класса от интерфейса
InfoMaster 10.01.2025
В современной разработке программного обеспечения существуют два основных механизма реализации абстракции: абстрактные классы и интерфейсы. Эти инструменты, хотя и схожи в своей основной цели -. . .
Как работать в Git
InfoMaster 10.01.2025
Git — это одна из наиболее популярных систем контроля версий, которая активно используется разработчиками по всему миру. Она позволяет эффективно управлять изменениями в коде, координировать работу. . .
Реализация передвижения персонажа в Unity3d на C#
InfoMaster 10.01.2025
Реализация передвижения персонажа в Unity3D начинается с правильной настройки проекта. Этот этап критически важен для создания отзывчивого и плавного управления. Рассмотрим основные шаги для создания. . .
Docker: руководство для начинающих
InfoMaster 10.01.2025
В современном мире разработки программного обеспечения контейнеризация стала неотъемлемой частью процесса создания и развертывания приложений. Docker, как ведущая платформа контейнеризации, произвела. . .
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru