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

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

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

Деструктор - C++

23.01.2013, 19:56. Просмотров 366. Ответов 3
Метки нет (Все метки)

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
#include <iostream>
#include <conio.h>
#define _CRTDBG_MAP_ALLOC
#include <crtdbg.h>
 
using namespace std;
 
class list{
private:
    int value;
    int size;
    list *next;
    list *prev;
    list *tail;
    list *head;
public:
    list();
    ~list();
    void add(int cvalue);
    void show();
    void search(int cvalue);
    void show_end();
};
 
list::list(){
    head = (list*)malloc(sizeof(value)+sizeof(next));
    head->value=NULL;
    head->next=NULL;
    head->prev=NULL;
    size = 1;
}
list::~list(){
    //Колхозан не пашет :(
    list *current;
    for(int i=0;i<size;i++){
        current = head;
        head = head->next;
        free(current);
    }
}
void list::add(int cvalue){
    list *current = head;
    if(current->value==NULL){
        current->value = cvalue;
    }else{
        for(int i=1;i<size;i++){
            current=current->next;
        }
        current->next=(list*)malloc(sizeof(value)+sizeof(next));
        current->next->value=cvalue;
        current->next->next=NULL;
        current->next->prev = current;
        tail=current;
        size++;
    }
}
void list::show(){
    list *current = head;
    while(current->next!=NULL){
        cout <<current->prev<<" "<<current->value << " " <<current->next<< " "<<current<<endl;
        current = current -> next;
    }
    cout <<current->prev<<" "<<current->value << " " <<current->next<< " "<<current<<endl;
}
 
void list::show_end(){//обработать немного
    list *current = tail;
    while(current->prev!=NULL){
        cout << current->value<<endl;
        current=current->prev;
    }
    cout<<current->value<<" "<<endl;
    
}
 
int main(){
    int n,b;
    list l;
    cin >> n;
    for(int i=0;i<n;i++){
        cin >> b;
        l.add(b);
    }
    cout << endl<<endl;
    l.show();
    cout << endl<<endl;
    l.show_end();
    getch();
    _CrtDumpMemoryLeaks();
return 0;
}
кидает ошибку повреждения кучи.
помогите че не так не пойму
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.01.2013, 19:56
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Деструктор (C++):

Почему создается виртуальный деструктор A, а в таблице виртуальных функций лежит деструктор B - C++
Почему я делаю виртуальным деструктор A, а в таблице виртуальных функций лежит деструктор B?

Деструктор - C++
Не понимаю почему в проге не работает строка cout &lt;&lt; &quot;Удаляем элемент списка!&quot;; вроде деструктор вызываеться автоматически, как пишет...

Деструктор - C++
В каком случае необходимо явно определять деструктор?

Деструктор - C++
Вроде все просто но чето никак не работает Задача: Написать программу в которой Конструктор класса MyCl выводит сообщение на...

Деструктор - C++
Добрый вечер!мне нужна одна программа для примера(рабочая),но это тему мы коснулись слегка..хотел попросить у кого есть...

Деструктор - C++
Ребята, объясните, пожалуйста, где, как и когда в программе вызывается деструктор? Вот мой пример: #include &lt;iostream&gt; using namespace...

3
nexen
187 / 180 / 3
Регистрация: 27.01.2012
Сообщений: 1,335
23.01.2013, 20:13 #2
ну хоть где кидает ошибку то?
0
BARRAKUDA099
0 / 0 / 0
Регистрация: 16.09.2012
Сообщений: 6
23.01.2013, 20:19  [ТС] #3
Цитата Сообщение от nexen Посмотреть сообщение
ну хоть где кидает ошибку то?
В деструкторе

Добавлено через 1 минуту
цикл написал вроде должно работать. но... куча повреждена
0
wiseman33
4 / 2 / 1
Регистрация: 01.07.2012
Сообщений: 7
23.01.2013, 20:36 #4
Строки 26 и 49, посмотрите что вы действительно делаете там
помойму надо так
C++
1
2
3
4
5
//26 
head = (list*)malloc(sizeof(list));
 
//49 
current->next=(list*)malloc(sizeof(list));
1
23.01.2013, 20:36
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.01.2013, 20:36
Привет! Вот еще темы с ответами:

Деструктор - C++
Я написал деструктор, но препод сказал переделать так как надо было смотреть на то, как я выделял память. Помогите исправить. int **m6; ...

деструктор - C++
опять же проблема с лабой. помоги дописать деструктор. #include &quot;stdafx.h&quot; #include &lt;string&gt; #include &lt;iostream&gt; using...

Деструктор - C++
Доброго времени суток, есть некоторый класс и 2 функции подобны тем, что описаны ниже. В первой объявляется данный класс, обрабатывается и...

деструктор - C++
Для освобождения памяти динамически выделенных массивам надо использовать delete. требуется ли освобождать память выделенную под простой...


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

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

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