Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
25th_July
0 / 0 / 1
Регистрация: 01.03.2017
Сообщений: 32
1

Перегрузка оператора <<

08.11.2017, 20:07. Просмотров 332. Ответов 2
Метки нет (Все метки)

Хочу реализовать возможность вывода элемента массива в main. Для этого так понимаю нужно перегрузить оператор <<. С [] справился, объясните как быть с <<
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//DinMemory.h
template <class type>
 
class DinMemory {
public:
    DinMemory(int s);
private:
    type *ptr = NULL;
    int  size = 0;
public:
    void reSize();
    void setData();
    bool add();
    bool del();
    ~DinMemory();   
};


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
//Dinmemory.cpp
#include "DinMemory.h"
 
template <class type>
DinMemory<type>::DinMemory(int s) {
    if (s > 0) {
        this->size = s;
        this->ptr = new type[size];
        
    }
}
 
template <class type>
void DinMemory<type>::reSize() {
        int s;
        while (true) {
            cout << "Введите размер массива" << endl;
            cin >> s;
            if (s > 0) {
                size = s;
                break;
            }
            if (s <= 0)
                continue;
        }
    }
 
template <class type>
void DinMemory<type>::setData() {
    type elem;
    for (int i = 0; i < size; i++) {
        cout << "Введите " << i << " элемент:" << endl;
        cin >> elem;
        ptr[i] = elem;
    }
}
 
template <class type>
bool DinMemory<type>::del() {
    int pos;
    cout << "Введите номер удаляемого элемента" << endl;
    cin >> pos;
    if (pos > size)
        return false;
    type *temp = new type[size - 1];
    for (int i = 0; i < pos; i++) 
        temp[i] = ptr[i];
    for (int i = pos + 1; i < size; i++)    
        temp[i - 1] = ptr[i];
    delete[] ptr;
    ptr = temp;
    temp = NULL;
    size--;
    return true;
}
 
 
template <class type>
bool DinMemory<type>::add() {
    type elem;
    int pos;
    cout << "Укажите элемент для добавления" << endl;
    cin >> elem;
    cout << "Укажите позицию вставки" << endl;
    cin >> pos;
    if (pos > size)
        return false;
    type *temp = new type[size + 1];
    for (int i = 0; i < pos; i++) 
        temp[i] = ptr[i];
    temp[pos] = elem; 
    for (int i = pos; i < size; i++)    
        temp[i + 1] = ptr[i];
    delete[] ptr;
    ptr = temp;
    temp = NULL;
    size++;
    return true;
 
 
}
 
template <class type>
DinMemory<type>::~DinMemory() {
    delete[] ptr;
    ptr = NULL;
}
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.11.2017, 20:07
Ответы с готовыми решениями:

Перегрузка оператора [][]
допустим у меня есть клас Matrix и я хочу опедилить оператор доступа к его елементу как...

Перегрузка оператора ==
Создайте класс stroka. Класс должен включать поле (массив) типа char для хранения строки. Класс...

Перегрузка оператора ==
Пытаюсь перегрузить оператор == . Делаю так: В классе: class cData // класс дата { int ...

Перегрузка оператора <<
Доброго времени суток. В общем задача состоит в том, чтобы перегрузить операторы &gt;&gt; и &lt;&lt; для...

2
nmcf
6599 / 5804 / 2641
Регистрация: 14.04.2014
Сообщений: 24,708
08.11.2017, 20:14 2
<< может только весь массив выводить.
0
25th_July
0 / 0 / 1
Регистрация: 01.03.2017
Сообщений: 32
08.11.2017, 21:38  [ТС] 3
Цитата Сообщение от nmcf Посмотреть сообщение
<< может только весь массив выводить.
Не могли бы показать как? И как можно реализовать вывод по индексу?

Добавлено через 54 минуты
Попробовал кое-что написать, но получаю при компиляции "неоднозначный оператор <<"
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
#include <iostream>
using namespace std;
 
template <class type>
class DinMemory {
public:
    DinMemory();
    DinMemory(int s);
private:
    type *ptr = NULL;
    int  size = 0;
public:
    void reSize();
    void setData();
    bool add();
    bool del(); 
    type &operator[](int i);    
    friend ostream& operator << (ostream& out, type const& a);  //это
    ~DinMemory();   
};
 
template <class type>    //это
ostream& operator << (ostream& out, type const& a)
{
    out << a;
    return out;
};
Добавлено через 24 минуты
Докопался до истины сам, всем спасибо Вот реализация если что:
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
#include <iostream>
using namespace std;
 
template <class type>
class DinMemory {
public:
    DinMemory();
    DinMemory(int s);
private:
    type *ptr = NULL;
    int  size = 0;
public:
    int getSize();
    void reSize();
    void setData();
    bool add();
    bool del(); 
    type &operator[](int i);    
    friend ostream& operator << (ostream& out, DinMemory<type> const& a);
    ~DinMemory();   
};
 
template <class type>
ostream& operator << (ostream& out, DinMemory<type> const& a)
{
    out << a.ptr[];  //!!!если написать out << a.ptr[0], все равно будет выводить нужный элемент
    return out;
};
0
08.11.2017, 21:38
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.11.2017, 21:38

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Перегрузка оператора <=
Основная задача данного фрагмента отсортировать массив структур по полю name в алфавитном порядке,...

Перегрузка оператора <<
Как вот в таком классе перегрузить оператор &lt;&lt;? #ifndef MATRIXX_H #define MATRIXX_H #include...

Перегрузка оператора <
Здравствуйте. Есть класс треугольник(Triangle), надо перегрузить оператор &lt; для объектов класса...

Перегрузка оператора *=
как для заданного класса point перегрузить оператор *= всеми возможными способами (член класса,...


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

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

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