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

Типы данных в ООП - C++

Восстановить пароль Регистрация
 
stanis-morozov
15 / 15 / 1
Регистрация: 18.03.2012
Сообщений: 91
03.04.2012, 17:05     Типы данных в ООП #1
Добрый день!
Пишу на C++, начал изучать, ООП, сейчас учу перегрузку операторов. При этом обнаружил некоторое недопонимание типов переменных, из-за чего столкнулся со сбоями в программе. Можете, пожалуйста, объяснить смысл типа, например, type& T или const type& T? Просто, когда в классе присутствуют динамические массивы, размеры которых мы по ходу программы изменяем, то сталкиваемся со следующей проблемой:
переопределяем оператор сложения так:
C++
1
2
3
4
5
6
type& operator +(type &T1, type& T2)
{
    type T(T1);
    /*прибавляем к T, T2*/
   return T;
}
но тогда значение переменной T не передается оператору присваивания. Ему передается не пойми что, из-за чего программа аварийно завершается. Если же тип, возвращаемый оператором сложения поставить type, а не type&, и перегрузить конструктор копирования, то все работает. Однако, ведь передавать все значение класса каждый раз - это очень медленно, так ведь?
Жду ответов, заранее благодарен!!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.04.2012, 17:05     Типы данных в ООП
Посмотрите здесь:

Типы данных C++
типы данных C++
Типы Данных C++
C++ ООП.Разработать структуру элементов данных класса в виде динамической структуры данных
Типы данных C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
03.04.2012, 17:27     Типы данных в ООП #2
Цитата Сообщение от stanis-morozov Посмотреть сообщение
type& T
Ссылка на T
Цитата Сообщение от stanis-morozov Посмотреть сообщение
const type& T
Константная ссылка на T
Цитата Сообщение от stanis-morozov Посмотреть сообщение
переопределяем оператор сложения так:
Цитата Сообщение от stanis-morozov Посмотреть сообщение
type&
Возвращать ссылку на локальный не статический объект - круто. Никогда так не делайте.

А какой был вопрос? Только кратко, самое нужное выделите.
stanis-morozov
15 / 15 / 1
Регистрация: 18.03.2012
Сообщений: 91
03.04.2012, 17:56  [ТС]     Типы данных в ООП #3
Можете написать как должен выглядеть простенький класс, в котором есть динамически изменяющийся массив и перегрузить в нем, например, операторы + и =
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
03.04.2012, 18:44     Типы данных в ООП #4
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
#include <iostream>
#include <cstdlib>
#include <algorithm>
#include <stdexcept>
#include <cstring>
////////////////////////////////////////////////////////////////////////////////
template <class T>
class Foo
{
    std::size_t _size;
    std::size_t _realSize;
    T*          _arr;
    //--------------------------------------------------------------------------
    static const std::size_t STEP = 50;
    //--------------------------------------------------------------------------
public:
    explicit Foo(const std::size_t& size):
        _size(size),
        _realSize(STEP > size ? STEP : size + STEP),
        _arr(new T[_realSize])
    {
 
    }
    //--------------------------------------------------------------------------
    explicit Foo(): Foo(0)
    {
 
    }
    //--------------------------------------------------------------------------
    ~Foo()
    {
        delete[] _arr;
    }
    //--------------------------------------------------------------------------
    void push_back(const T elem)
    {
        if(_size == _realSize)
        {
            T* tmp = new T[_realSize];
            std::memcpy(tmp, _arr, _realSize * sizeof(T));
            delete[] _arr;
            _arr = new T[_realSize + STEP];
            std::memcpy(_arr, tmp, _realSize * sizeof(T));
            delete[] tmp;
            _realSize += STEP;
        }
        _arr[size++] = elem;
    }
    //--------------------------------------------------------------------------
    T& at(const std::size_t pos) const
    {
        if(_size > pos)
            return _arr[pos];
        else
            throw std::out_of_range("pos >= size");
    }
    //--------------------------------------------------------------------------
    const std::size_t size() const
    {
        return _size;
    }
    //--------------------------------------------------------------------------
    const Foo<T> operator+ (const Foo<T>& f)
    {
        Foo<T> ret(std::max(f.size(), _size));
 
        const std::size_t min = std::min(f.size(), _size);
        const std::size_t max = std::max(f.size(), _size);
 
        for(std::size_t i = 0; i < min; ++i)
            ret.at(i) = _arr[i] + f.at(i);
 
        for(std::size_t i = min; i < max; ++i)
            ret.at(i) = _arr[i];
 
        for(std::size_t i = min; i < max; ++i)
            ret.at(i) = f.at(i);
 
        return ret;
    }
    //--------------------------------------------------------------------------
    Foo& operator= (const Foo& f)
    {
        _size = f.size();
        if(_realSize)
            delete[] _arr;
        _realSize = f._realSize;
        _arr = new T[_realSize];
        std::memcpy(_arr, f._arr, _realSize * sizeof(T));
    }
};
////////////////////////////////////////////////////////////////////////////////
int main()
{
    Foo<int> f1(3);
    Foo<int> f2(5);
    for(std::size_t i = 0; i < 3; ++i)
        f1.at(i) = i;
    for(std::size_t i = 0; i < 5; ++i)
        f2.at(i) = i * 2;
    Foo<int> f3 = f1 + f2;
    for(std::size_t i = 0; i < 5; ++i)
        std::cout << f3.at(i) << " ";
    std::cout << std::endl;
    return 0;
}
Toshkarik
 Аватар для Toshkarik
1139 / 856 / 50
Регистрация: 03.08.2011
Сообщений: 2,381
Завершенные тесты: 1
03.04.2012, 19:24     Типы данных в ООП #5
Цитата Сообщение от soon Посмотреть сообщение
Константная ссылка на T
Скорее ссылка на константный объект. Ссылка сама по себе константа.
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
03.04.2012, 19:47     Типы данных в ООП #6
Toshkarik, я бы все-таки называл это константной ссылкой. Раз объект по-прежнему можно изменить не через ссылку, значит объект не константа.
Toshkarik
 Аватар для Toshkarik
1139 / 856 / 50
Регистрация: 03.08.2011
Сообщений: 2,381
Завершенные тесты: 1
03.04.2012, 19:50     Типы данных в ООП #7
soon, в книгах почему то же пишут везде ссылка на константу.
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
03.04.2012, 19:56     Типы данных в ООП #8
Toshkarik, а в cppreferenc-ах и ему подобных, а так же в клссах пишут const_reference, а не reference_to_const. Как говорится, хоть горшком обзовите, только в печь не суйте.
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
03.04.2012, 20:11     Типы данных в ООП #9
explicit
Я вас очень прошу, ну не грузите новичков экспликтами. Признайте, это довольно редкая вещь и не стоит её писать просто, "чтоб была". Учебная программа тем ценнее, чем меньше в ней лишнего и демонстрируется только то, на что она нацелена. Вот проходят они операторы и конструкторы. И не нужно грузить экспликтами никого.
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
03.04.2012, 20:16     Типы данных в ООП #10
Kuzia domovenok, я пишу не только для участников этого форума, я также пишу для себя. А для себя я всегда буду писать explict. И не такая это уж редкая вещь.
Toshkarik
 Аватар для Toshkarik
1139 / 856 / 50
Регистрация: 03.08.2011
Сообщений: 2,381
Завершенные тесты: 1
03.04.2012, 20:18     Типы данных в ООП #11
Kuzia domovenok, вот как раз когда проходят перегрузку и конструкторы да и классы вообще, тогда и нужно, я считаю, говорить о explicit.
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
03.04.2012, 20:33     Типы данных в ООП #12
Цитата Сообщение от Toshkarik Посмотреть сообщение
Kuzia domovenok, вот как раз когда проходят перегрузку и конструкторы да и классы вообще, тогда и нужно, я считаю, говорить о explicit.
Я в любом случае считаю, что программы надо писать как можно проще. Даже помимо экспликтов (которые я всё равно считаю стоит использовать только в редких специфических случаях и предварительно объяснять необходимость в них, а не потому что в языке они есть) ты в примере использовал шаблоны и стандартную библиотеку. Ну ЗАЧЕМ??? Где у ТС сказано, что ему нужен шаблонный класс?
Я считаю, что особенно в учебных программах выпендриваться не надо и прежде чем что-то свободно использовать, надо досконально изучить. То есть: изучаешь операторы - вот и изучай, не городи шаблонов, пока с одним не разобрался.

Добавлено через 2 минуты
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
ты в примере использовал шаблоны и стандартную библиотеку
Ах, пример не твой, я про soon значит говорил
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.04.2012, 21:00     Типы данных в ООП
Еще ссылки по теме:

Типы данных: есть ли универсальный тип, который может заменить все типы данных в Си? C++
C++ Типы данных
C++ Типы данных

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

Или воспользуйтесь поиском по форуму:
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
03.04.2012, 21:00     Типы данных в ООП #13
Не будем превращать топик в подобие ветки о необходимости инкапсулирования данных. Вас переубеждать - себе дороже.
Yandex
Объявления
03.04.2012, 21:00     Типы данных в ООП
Ответ Создать тему
Опции темы

Текущее время: 13:01. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru