Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Alex_Faru
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 11
#1

Динамические структуры (линейные списки): Run-Time Check Failure #2 - Stack around the variable ... was corrupted. - C++

16.01.2012, 05:41. Просмотров 788. Ответов 11
Метки нет (Все метки)

Снова необходима ваша срочная помощь. Программа по димнамическим структурам на С++. Выполняет все необходимые действия, но при программном выходе и пустом, незаполненном списке всплывает ошибка: Run-Time Check Failure #2 - Stack around the variable 'CZN' was corrupted.

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

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
113
114
115
116
117
118
#include "stdafx.h"
#include "conio.h"
 
 
struct CARD {
    int Nroom;
    int floor;
    int s;
    int Adr;
    CARD*next;
};
CARD*head=NULL;//присваиваем первому элементу NULL
 
////Объявление функций///
CARD*Addnew (CARD*Head, int Nroom, int floor, int s, int Adr);
void VIVOD (CARD*Head);
void search (int Nroom, int floor, int s);
void mem_del (CARD*); 
 
int _tmain(int argc, _TCHAR* argv[])
{
    unsigned char CZN=0;
    printf ("Komandi:\n 1 - zapis\n2- vivod\n3-zayavka\n4-pomosh\n5-vihod\n");
    while (CZN<5) {
    printf ("Enter command: ");
    scanf ("%d", &CZN);
 
    switch (CZN) {
    case 1: {                   //Команда формирования списка
        int zn[4];
        printf ("Kolichestvo komnat: ");
        scanf ("%d",&zn[0]);
        printf ("Etazh: ");
        scanf ("%d",&zn[1]);
        printf ("Ploshyad': ");
        scanf ("%d",&zn[2]);
        printf ("Adres: ");
        scanf ("%d", &zn[3]);
        head=Addnew(head, zn[0],zn[1],zn[2],zn[3]);
        CZN=0;
        break;}
    case 2: {VIVOD(head); break;} //Команда вывода
    case 3: {                   //команда ввода заявки
        int zn[3];
        printf ("Kolichestvo komnat: ");
        scanf ("%d",&zn[0]);
        printf ("Etazh: ");
        scanf ("%d",&zn[1]);
        printf ("Ploshyad: ");
        scanf ("%d",&zn[2]);
 
    search(zn[0],zn[1],zn[2]); //вызов функции поиска
    CZN=0;
        break;}
    case 4:{printf ("Komandi:\n 1 - zapis\n2- vivod\n3-zayavka\n4-pomosh\n5-vihod");}//команда вызова справки
    default: break;
        } 
    }
 
    if (head!=NULL) mem_del(head);
 
        
    return 0;
}
CARD*Addnew (CARD*Head, int Nroom, int floor, int s, int Adr)
        {
            CARD*H= new CARD;
            H->next=Head;   // присваиваем новому элементу значение следующего
            H->Nroom=Nroom; //
            H->floor=floor; // присваиваем новому элементу списка значения атрибутов    
            H->s=s;         //
            H->Adr=Adr;     //
            return H;
        }
 
void VIVOD (CARD*Head)
    {
    CARD*np=Head;
    while (np!=NULL)
    {
        printf ("===Rooms: %d, Floor: %d, S: %d, Adres: %d\n", np->Nroom, np->floor, np->s, np->Adr);
        np=np->next;
    }
 
    }
void search (int Nroom, int floor, int s)
{
    int proc=0;
    CARD*np=head;
    CARD*last=head;
    while (np!=NULL)
    {
        if (np->Nroom==Nroom && np->floor==floor){ //проверка на условие задания
            proc=s*0.1;// вычисляем процентное соотношение площадей
            if (np->s>=s-proc && np->s<=s+proc){    //проверка на условие задания
            printf ("===Rooms: %d, Floor: %d, S: %d, Adres: %d\n", np->Nroom, np->floor, np->s, np->Adr);
            last->next=np->next;//перескакивание найденного элемента
            delete np;//удаление элемента из стека
            break;
            }
        }
 
    last=np;
    np=np->next;
    }
}
 
void mem_del (CARD*Head)
{
    CARD* del=Head;
    while (Head)
    {
        del=Head;
        Head=head->next;
        delete del;
    }
    return;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.01.2012, 05:41
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Динамические структуры (линейные списки): Run-Time Check Failure #2 - Stack around the variable ... was corrupted. (C++):

заполнение структуры, где-то ошибка run-time check failure #2 stack around the variable a was corrupted - C++
Просмотрите пожалуйста код, ошибка run-time check failure #2 stack around the variable 'Data' was corrupted. Почитал, что она возникает,...

Run-Time Check Failure #2 - Stack around the variable 'a' was corrupted - C++
Добрый день подскажите что это означает и как исправить данное сообщение Run-Time Check Failure #2 - Stack around the variable 'a' was...

Run-Time Check Failure #2 - Stack around the variable 'a' was corrupted. - C++
Здравствуйте. Пишу две функции: ввод и вывод целочисленного массива, в конце программы вылетает такая ошибка, и я уже понял...

Run time check failure #2 stack around the variable was corrupted - C++
Помогите пожалуйста найти ошибку, только начала писать код и уже не могу найти ошибку void main() { //руссификатор ...

Run-Time Check Failure #2 - Stack around the variable 'dt' was corrupted - C++
Я понимаю что ошибка говорит о том что где-то вышел за диапазон массива, я перепроверил все циклы, вроде все гладко с индексами. данная...

Run-Time Check Failure #2 - Stack around the variable 'n' was corrupted - C++
При вводе значение более трёх символов (это значение конечно можно регулировать) появляется следующее сообщение Run-Time Check Failure #2 -...

11
NoMasters
Псевдослучайный
1762 / 1105 / 73
Регистрация: 13.09.2011
Сообщений: 3,141
16.01.2012, 06:34 #2
Цитата Сообщение от Alex_Faru Посмотреть сообщение
Не терпит отлагательств!
Во фриланс тогда.
Мы должны угадать, при каких обстоятельствах происходит ошибка? И вообще собирать и читать _это_ то ещё удовольствие. Кто тебя научил использовать капс в именах типов(только не надо про винапи, оно не для людей)? А уж очередное
C
1
int _tmain(int argc, _TCHAR* argv[])
вообще меня печалит до ужаса.Это что за среда такое вытворяет?
0
Alex_Faru
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 11
16.01.2012, 06:49  [ТС] #3
При каких обстоятельствах происходит ошибка я описал, но могу объяснить подробнее: программа организована по средством меню так, что при выборе команды под номером пять работа завершается. Ошибка происходит в том случае если при запуске программы не была сначала выполнена команда один, вносящая новый элемент в список, а сразу выбрана команда выхода, то есть, пять.

На счёт среды. Если я вас правильно понял, то вот мой ответ: Visual Studio 2008. Это её стандартная запись мэйна, и на работоспособность программ вроде не влияет (мной по крайней мере не замечено различий).

По прежнему надеюсь на помощь. В прошлый раз мне здесь помогли, надеюсь, помогут и в этот.
0
NoMasters
Псевдослучайный
1762 / 1105 / 73
Регистрация: 13.09.2011
Сообщений: 3,141
16.01.2012, 06:53 #4
Цитата Сообщение от Alex_Faru Посмотреть сообщение
на работоспособность программ вроде не влияет
Но нигде, кроме студии, оно не соберется. За часть наезда по поводу неполного описания извиняюсь, просмотрел, взгляд сразу уперся к страшный(по моему мнению) код.
Вы не пишите в next NULL, поэтому дойдя до конца списка, mem_del пытаетс освободить память по невалидному указателю.
0
Alex_Faru
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 11
16.01.2012, 06:59  [ТС] #5
Ничего, код ведь и правда громоздкий. То есть, какую строку нужно исправить в mem_del?
0
NoMasters
Псевдослучайный
1762 / 1105 / 73
Регистрация: 13.09.2011
Сообщений: 3,141
16.01.2012, 07:15 #6
Кхм, я опять не прав. Всё-таки ночью надо спать. Думал, вы в конец списка элементы добавляете. Сейчас пересмотрю, минуту

Добавлено через 10 минут
в mem_del:
C++
1
Head=head->next;
head и Head разные переменные. Регистрозависимость же. head у вас глобальная переменная, указывающая на начало
0
Alex_Faru
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 11
16.01.2012, 07:26  [ТС] #7
Да всё так и есть. Как же мне тогда должным образом организовать удаление памяти?
0
NoMasters
Псевдослучайный
1762 / 1105 / 73
Регистрация: 13.09.2011
Сообщений: 3,141
16.01.2012, 07:44 #8
Достаточно поменять одну букву
C++
1
2
3
4
5
6
7
8
9
10
11
void mem_del (CARD*Head)
{
        CARD* del=Head;
        while (Head)
        {
                del=Head;
                Head=Head->next;
                delete del;
        }
        return;
}
Хотя инициализация del тоже не нужна.
0
Alex_Faru
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 11
16.01.2012, 07:48  [ТС] #9
К сожалению, так я уже пробовал. Ошибка никуда не исчезла.
0
NoMasters
Псевдослучайный
1762 / 1105 / 73
Регистрация: 13.09.2011
Сообщений: 3,141
16.01.2012, 08:07 #10
У меня с этим исправлением и небольшим количеством косметики, позволяющим собрать код вне студии, у меня работает без ошибок, valgrind тоже утверждает, что с памятью всё хорошо.
0
Alex_Faru
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 11
16.01.2012, 08:12  [ТС] #11
Ну что ж, спасибо вам огромное за ваш труд!))
0
NoMasters
Псевдослучайный
1762 / 1105 / 73
Регистрация: 13.09.2011
Сообщений: 3,141
16.01.2012, 08:26 #12
всмотрелся в search, там проблема, если удаляется первый элемент. Вместо 97
C++
1
2
3
4
if(np == head)
    head = np->next;
else
    last->next=np->next;
0
16.01.2012, 08:26
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.01.2012, 08:26
Привет! Вот еще темы с ответами:

Run-Time Check Failure #2 - Stack around the variable 'A' was corrupted - C++
Определить класс вектор (одномерный числовой массив). В класс включить конструктор для определения вектора по количеству элементов,...

Run-Time Check Failure #2 - Stack around the variable 'C' was corrupted - C++
#include &lt;iostream&gt; #include &lt;iomanip&gt; using namespace std; int main() { const int n=10; int i,A,B,C,k; ...

Run-Time Check Failure #2 - Stack around the variable 'a' was corrupted - C++
Всем привет, начал недавно писать на с++, делаю программу по заполнению и сортировке элементов массива. При выполнении не показывает ...

Run-Time Check Failure #2 - Stack around the variable 'flag' was corrupted - C++
выдаёт такую ошибку по завершению выполнения этой пп-мы. в чём может быть дело? CfgOfSquare { POINT pt; HBRUSH brush; HPEN...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru