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

Странное поведение в коде - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как загрузить DLL? http://www.cyberforum.ru/cpp-beginners/thread1237405.html
Я раньше с DLL дела не имел, но вот тут такая задача появилась. Есть DLL который сканирует процессы и что то там делает Как мне его загрузить/запустить или что там делать нада? я просто вобще не...
C++ Динамическое выделение памяти для массива указателей на char Доброго времени суток! пытаюсь выделить память для массива указателей на char следующий код #include <iostream> #include <string.h> #include <sstream> #include <stdlib.h> using namespace std;... http://www.cyberforum.ru/cpp-beginners/thread1237402.html
Шаблон класса Wrapper C++
Как мне написать такой шаблон. template<typename WrappedType> class Wrapper { protected: template <typename R, typename... Args>
Очередь «первый вошел — первый вышел» (FIFO) C++
Очередь — это устройство для хранения данных, похожее на стек. Отли-чие в том, что в стеке последний сохраненный элемент будет первым извлеченным, тогда как в очереди первый сохраненный элемент будет...
C++ Кроссплатформенное приложение http://www.cyberforum.ru/cpp-beginners/thread1237357.html
Сразу хочу сказать что с С++ только знакомлюсь (есть опыт в web языках). Вот к примеру мне нужно сделать такую вот задачку - по экрану передвигается объект с помощью стрелок и мыши, а так же есть...
C++ Type name expected Ребят, туплю, что здесь не так с типом имени? int InitializeNodes(char *pdata, DWORD dwSize) подробнее

Показать сообщение отдельно
QGuest
8 / 8 / 0
Регистрация: 08.01.2013
Сообщений: 85

Странное поведение в коде - C++

01.08.2014, 21:14. Просмотров 261. Ответов 3
Метки (Все метки)

Есть два класса: ArrayList<T> и Array<T> (реализация в конце поста).
И есть такой код:
C++
1
2
3
ArrayList<int> list = { 1, 2, 3 };
Array<int> arr = list.clone().asArray();
cout << arr[0]; // Вывод -17891602 вместо 1
Собственно понятно, что результат метода clone() удаляется после того как вызывается asArray(). То есть обьект Array<int> arr существует, но ссылается на удаленный участок памяти копии обьекта ArrayList<int> list.
И если немного изменить код, то все будет работать корректно:
C++
1
2
3
4
ArrayList<int> list = { 1, 2, 3 };
ArrayList<int> clone = list.clone();
Array<int> arr = clone.asArray();
cout << arr[0]; // Вывод: 1, как и должно быть
Вопрос: Почему? Как исправить реализацию ArrayList<T> или Array<T>, чтоб работал первый вариант?

Реализация ArrayList<T>:
Кликните здесь для просмотра всего текста
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
template<typename T>
class ArrayList {
private:
    vector<T> data;
 
public:
    ArrayList() {}
    ArrayList(initializer_list<T> list) : data(list) {}
    
    template<class it, class = typename enable_if<_Is_iterator<it>::value, void>::type>
    ArrayList(it first, it last) : data(first, last) {}
    
    ArrayList(const ArrayList<T>& other) {
        for (int i = 0; i < other.size(); i++) {
            data.push_back(other.get(i));
        }
    }
 
    ArrayList<T>& operator=(const ArrayList<T>& other) {
        data = vector(other.data);
        return *this;
    }
 
    ArrayList<T> clone() {
        return ArrayList(*this);
    }
 
    Array<T> asArray() {
        return Array<T>(&data.begin()[0], size());
    }
 
    void remove(int index) { data.erase(data.begin() + index); }
    void add(T& value) { data.push_back(value); }
    T& get(int index) { return data[index]; }
    void insert(T& value, int index) { data.insert(data.begin() + index, value); }
    int size() const { return data.size(); }
};

Реализация Array<T>:
1
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
template<typename T>
class Array {
private:
    T* data;
    size_t lengthValue = 0;
public:
 
    Array(size_t length) {
        lengthValue = length;
        data = new T[length];
    }
 
    Array(T* data, size_t length) {
        if (data == null) {
            throw invalid_argument("Array pointer can`t be null.");
        }
        lengthValue = length;
        this->data = data;
    }
 
    Array(const Array& obj) {
        lengthValue = obj.lengthValue;
        data = new T[lengthValue];
        for (size_t i = 0; i < lengthValue; i++) {
            data[i] = obj.data[i];
        }
    }
 
    Array(initializer_list<T> list) {
        lengthValue = list.size();
        data = new T[lengthValue];
        for (size_t i = 0; i < lengthValue; i++) {
            data[i] = list.begin()[i];
        }
    }
 
    T& operator[](int index) {
        if (index < 0 || index >= lengthValue) {
            throw out_of_range("Array index out of range.");
        }
        return data[index];
    }
 
    Array<T>& operator=(const Array<T>& other) {
        delete[] data;
 
        lengthValue = other.lengthValue;
        data = new T[lengthValue];
        for (size_t i = 0; i < lengthValue; i++) {
            data[i] = other.data[i];
        }
        return *this;
    }
 
    operator T*() { return data; }
    size_t length() const { return lengthValue; }
    ~Array() { delete[] data; }
};
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru