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

_BLOCK_TYPE_IS_VALID(pHead->nBlockUse) - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Из одного статического массива получить три динамических http://www.cyberforum.ru/cpp-beginners/thread1799405.html
Всем привет. Возникла сложность с такой задачей. Написать функцию, которая получает указатель на статический массив и его размер. Функция распределяет положительные, отрицательные и нулевые элементы в отдельные динамические массивы. Код я написал, но постоянно появляется ошибка. Вроде как не отчищается память. но как исправить не могу разобраться. Может кто помочь? #include <iostream>...
C++ Поясните как работает постфиксный и префиксный оператор на примере Здравствуйте. Здесь префиксный понятно, а что если изменить на постфиксный, как код будет работать? vector<int>::size_type cnt=ivec.size(); for ( vector<int>::size_type ix=0; ix!=ivec.size(); ++ix,--cnt) ivec=cnt; http://www.cyberforum.ru/cpp-beginners/thread1799354.html
C++ Acces Violation в dll
Добрый день. Иньекчу dll в процесс struct UL2ConsoleWnd {}; UL2ConsoleWnd *_consoleWnd = NULL; extern "C" { __declspec(dllexport) void Test() { Utils::Log(_consoleWnd);
Сравнение и замена текста в 2 txt файлах С++ C++
Помогите, пожалуйста, кодом решения следующей проблемы есть два тхт файла первый содержит текст следующего вида AAA;BBB;CCC DDD;BBB;CCC GGG;BBB;CCC второй содержит текст следующего вида
C++ Использование слова extern для структур http://www.cyberforum.ru/cpp-beginners/thread1799296.html
В одном из файлов проекта задана структура: struct TMsgTV { int X,Y; char *Msg; } Далее была объявлена константа-массив этого типа:
C++ Заполнить элементы массива в промежутке от min до max элемента значением среднего арифметического Создать массив из 100 элементов, заполнить от 0 до 26, в промежутке от минимального до максимального элемента, заполнить все элементы значением среднего арифметического всех элементов массива Разные варианты пробовал, но никак! Можете помочь? Первое сделал, а вот это что-то новое!!! как заполнить в промежутке? (от минимального до максимального элемента) все элементы значением среднего... подробнее

Показать сообщение отдельно
Chronid
2 / 2 / 0
Регистрация: 23.03.2015
Сообщений: 41
27.08.2016, 14:27     _BLOCK_TYPE_IS_VALID(pHead->nBlockUse)
Нужна помощь гуру.
Искать ошибку тут в коде ненужно, сам все нашёл, мне нужно объяснение почему так происходит, увы нигде не нашёл внятного ответа. Ниже написана простенькая реализация класса, в ней присутствует динамическое выделение памяти под строку символов. Наследования нет. Реализован конструктор копирования и перегружен оператор присваивания.
Вопрос в том почему происходит(как я понял двойное освобождение одного участка динамической памяти). Я присваиваю один объект другому, оба объекта одного класса, правильно(как мне кажется) реализованы конструкторы и перегружен оператор, у переменных(указателей) каждого объекта строго свои участки динамической памяти. Сколько я не смотрел, неоткуда браться двойному освобождению одного и того же участка памяти. НО ЧЕРТ ВОЗЬМИ ОНО ОТКУДА ТО БЕРЕТСЯ!
То есть присваивание объекта одного к другому происходит без проблем с любой одной из описанных функций(конструктор копирования или перегрузка оператора присваивания). Но если хотя бы одного из них нет,то при удалении присвоенного объекта вылетает ошибка(название которой в заголовке темы). Соответственно, если обе функции описаны в классе то все гладко.
Ответе пожалуйста, почему так?

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
#include <iostream>
using namespace std;
 
class A{
private:
    size_t size;
    char *str;
public:
    A(size_t size = 0, char* str = 0) : size(size), str(new char[size]) {
        if (size > 0)
        for (size_t i = 0; i != this->size; ++i)
            this->str[i] = str[i];
    }
    //Диструктор
    ~A(){ delete[] str; str = 0; }
//------------------------------------------------------------
    //Конструктор копирования                       //
    A(const A &a) : size(a.size), str(new char[size]){      // 
        for (size_t i = 0; i != size; ++i)              //
            str[i] = a.str[i];                      //
    }                                       //
//------------------------------------------------------------         
    void show(){
        cout << "size: " << size << endl;
        cout << "str: " << str << endl;
    }
    void swap(A &a){
        std::swap(size, a.size);
        std::swap(str, a.str);
    }
//------------------------------------------------------------
    //Перегрузка оператора присваивания             //
    A &operator=(const A &a){                           //
        if (this != &a){                            //
            A(a).swap(*this);                       //
            return *this;                       //
        }                                   //
    }                                       //
//------------------------------------------------------------
};
 
int main(){
    setlocale(LC_ALL, "");
    A a1(15, "Привет мир!");
    A a2 = a1;    //Конструктор копирования 
    a1.show();
    //Оператор присваивания и конструктор копирования, копирования происходит с любым одним из последних но
//  a2 = a1;    //без любого из них происходит ошибка при освобождении динамической памяти
    a2.show();
 
    system("pause");
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 19:57. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru