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

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

Войти
Регистрация
Восстановить пароль
 
 
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
#1

перегрузка [] - C++

01.02.2013, 15:07. Просмотров 789. Ответов 20
Метки нет (Все метки)

Как перегрузить operator[] так, чтобы когда я модифицировал массив то вызывалась простая версия, а когда просто выводил то const версия?

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
#ifndef array_h
#define array_h
 
template<typename T>
class Array {
public:
    Array();
    Array(int);
    ~Array();
    T &operator[](int);
protected:
    void add_new_elem(int);
    T* mElem;
    int mSize;
};
 
 
template<typename T>
Array<T>::Array()
{
    mSize = 1;
    mElem = new T[mSize];
}
 
template<typename T>
Array<T>::Array(int size)
{
    mSize = size;
    mElem = new T[mSize];
}
 
template<typename T>
Array<T>::~Array()
{
    delete [] mElem;
}
 
template<typename T>
void Array<T>::add_new_elem(int newSize)
{
    T* newElem = new T[newSize];
 
    for(int i=0;i<newSize;i++)
        newElem[i] = mElem[i];
 
    mSize = newSize;
    delete [] mElem;
    mElem = newElem;
}
 
template<typename T>
T &Array<T>::operator[](int x)
{
    if(x>=mSize)
        add_new_elem(x+1);
    return (mElem[x]);
}
 
 
#endif
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.02.2013, 15:07
Здравствуйте! Я подобрал для вас темы с ответами на вопрос перегрузка [] (C++):

Перегрузка в виде метода VS Перегрузка в виде функции друг - C++
Привет! Собственно сабж: В каких случаях используется перегрузка в виде метода, а когда в виде функции друг? Добавлено через 4...

Множественное наследование, Перегрузка функций, Перегрузка операторов, Использование дружественных функций и классов, Использование шаблонов классов - C++
Здравствуйте!!! Я бы хотел попросить помоч решить...ну или скинуть примеры таких задач, если вдруг у вас они завалялись на компе или...

Перегрузка [][] - C++
Возможно ли для данного класса обеспечить перегрузку жвойных скобок с тем, чтобы в программе можно было использовать выражения типа: ...

Перегрузка в c++ - C++
Собственно для чего нужна перегрузка функций или операторов ?

перегрузка >> и << - C++
Решил попробовать перегрузить операции ввода и вывода,почему то выводятся 0, вместо нужных значений,подскажите в чем косяк #include...

Перегрузка new - C++
Дайте примеры на перегрузку. #define n ... // Некая целая константа class a { ... }; // Некий класс a *p=new a; // Здесь должен быть...

20
John Prick
801 / 734 / 145
Регистрация: 27.07.2012
Сообщений: 2,107
Завершенные тесты: 3
01.02.2013, 15:14 #2
Две версии сделай:
C++
1
2
3
4
5
6
template<typename T>
class Array {
public:
    T & operator[](int);
    const T & operator[](int) const;
};
0
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
01.02.2013, 15:15  [ТС] #3
Я делал две версии, но вызывается чего-то только одна!
0
John Prick
801 / 734 / 145
Регистрация: 27.07.2012
Сообщений: 2,107
Завершенные тесты: 3
01.02.2013, 15:19 #4
Цитата Сообщение от The_bolT Посмотреть сообщение
Я делал две версии, но вызывается чего-то только одна!
Константная версия будет вызываться только для константного объекта.

Добавлено через 1 минуту
C++
1
2
3
4
5
6
7
8
9
10
11
template <class T>
void func1(Array<T> & Arr)
{
    T a = Arr[0]; // неконстантная версия
}
 
template <class T>
void func2(const Array<T> & Arr)
{
    T a = Arr[0]; // константная версия
}
1
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
01.02.2013, 15:42  [ТС] #5
я хочу реализовать проверку на выход за пределы массива, но тут возникла такая праблема: если будет вызываться одна и та функция [] то по сути в одну сторону можно проконтролировать а в другую нет, если i <0 еще нормально, а если i> size то тоже проконтролировать можно, но памяти под новые элементы не выделится больше никогда! Посоветуйте что-нибудь!
0
silent_1991
Эксперт С++
4985 / 3042 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
04.02.2013, 09:54 #6
The_bolT, отдышитесь и сформулируйте свою мысль более понятно. Что у вас там в одну сторону контролируется, а в другую нет, и что там контролируется но не выделяется?
0
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
04.02.2013, 15:37  [ТС] #7
В С + + не контролируется выход за границы массива, вот я и решил написать программу с динамическим массивом чтобы можно было контролировать это, например:
создали мы массив размером 5 и заполнили его числами, и я хочу, чтобы моя программа не допускала такого
arr [6] = 3;
чтобы на этом моменте вибиволо сообщения или выходило из программы.
Вот я и подумал написать две версии [] обна для модификации массива, а вторая, константная версия, только для чтения этого массива. Если не будет две версии, у меня получится фикссований массив, который после инициализации не сможет менять свой ​​размер. Я подумал написать что-то похоже к этому, но размер массива затем изменить нельзя.
C++
1
2
3
4
5
6
7
8
template<typename T>
T &Array<T>::operator[](int x)
{
    //if(x<0 && x>=size) exit(1);                        
    if(x>=mSize)
        add_new_elem(x+1);
    return (mElem[x]);
}
Добавлено через 35 минут
Решил сделать по другому, добавить функцию push_back чтобы добавлять элементы а в operator[] генерировать исключения, но почему я это исключение перехватить не могу?
Кликните здесь для просмотра всего текста
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
#ifndef array_h
#define array_h
 
 
template<typename T>
class Array {
public:
    Array();
    Array(int);
    ~Array();
    T &operator[](int) const;
    bool operator==(const Array<T>&);
    bool operator!=(const Array<T>&);
    void push_back(T);
    int size() const;
protected:
    void add_new_elem(int);
    T* mElem;
    int mSize;
};
 
template<typename T>
void Array<T>::push_back(T X)
{
    add_new_elem(mSize+1);
    mElem[mSize-1] = X;
}
 
template<typename T>
bool Array<T>::operator!=(const Array<T>& obj)
{
    if(mSize!=obj.mSize){
        return true;}
 
        for(int i=0;i<mSize;i++)
            if(mElem[i] != obj.mElem[i]) return true;
     return false;
}
 
template<typename T>
bool Array<T>::operator==(const Array<T>& obj)
{
    if(mSize!=obj.mSize){
        return false;}
 
        for(int i=0;i<mSize;i++)
            if(mElem[i] != obj.mElem[i]) return false;
     return true;
}
 
template<typename T>
int Array<T>::size() const
{
    return (mSize);
}
 
template<typename T>
Array<T>::Array()
{
    mSize = 1;
    mElem = new T[mSize];
}
 
template<typename T>
Array<T>::Array(int size)
{
    mSize = size;
    mElem = new T[mSize];
}
 
template<typename T>
Array<T>::~Array()
{
    delete [] mElem;
}
 
template<typename T>
void Array<T>::add_new_elem(int newSize)
{
    T* newElem = new T[newSize];
 
    for(int i=0;i<newSize;i++)
        newElem[i] = mElem[i];
 
    mSize = newSize;
    delete [] mElem;
    mElem = newElem;
}
 
template<typename T>
T &Array<T>::operator[](int x) const
{
    if(x >= mSize || x < 0){ 
        string e = "Error";
        throw invalid_argument(e);}
    return (mElem[x]);
}
 
 
#endif

Кликните здесь для просмотра всего текста
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
#include <iostream>
#include "array.h"
 
using namespace std;
 
int main()
{
    Array<int> arr,arr2;
    for(int i=0;i<8;i++){
        arr[i]=i+1;
    }
    cout<<endl<<arr.size()<<endl<<endl;
    for(int i=0;i<arr.size();i++)
        cout<<arr[i]<<" ";
    cout<<endl;
    try{
    arr[9] = 5;
    }
    catch(...)
    {cout<<"adw";
    }
    cout<<endl;
    system("pause>0");
    return 0;
}
0
silent_1991
Эксперт С++
4985 / 3042 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
04.02.2013, 16:24 #8
The_bolT, ну вот, теперь совсем другое дело, теперь ясно, чего вы хотели.

Цитата Сообщение от The_bolT Посмотреть сообщение
но почему я это исключение перехватить не могу?
Потому что вы его и не ловите. Исключение происходит не там, где вы предполагаете, в блоке try, а раньше, в строке 10, на первой же итерации цикла. Ведь вы сами сказали, что добавили метод push_back для добавления элемента, но всё равно пытаетесь использовать для этого оператор индексации.
1
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
04.02.2013, 16:39  [ТС] #9
Теперь появилась другая проблема, массив имеет один элемент больше чем я задаю, и я не могу найти где добавляется лишняя единица!
Кликните здесь для просмотра всего текста
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
#ifndef array_h
#define array_h
 
 
template<typename T>
class Array {
public:
    Array();
    Array(int);
    ~Array();
    T &operator[](int) const;
    bool operator==(const Array<T>&);
    bool operator!=(const Array<T>&);
    void push_back(T);
    int size() const;
protected:
    void add_new_elem(int);
    T* mElem;
    int mSize;
};
 
template<typename T>
void Array<T>::push_back(T X)
{
    add_new_elem(mSize+1);
    mElem[mSize-1] = X;
}
 
template<typename T>
bool Array<T>::operator!=(const Array<T>& obj)
{
    if(mSize!=obj.mSize){
        return true;}
 
        for(int i=0;i<mSize;i++)
            if(mElem[i] != obj.mElem[i]) return true;
     return false;
}
 
template<typename T>
bool Array<T>::operator==(const Array<T>& obj)
{
    if(mSize!=obj.mSize){
        return false;}
 
        for(int i=0;i<mSize;i++)
            if(mElem[i] != obj.mElem[i]) return false;
     return true;
}
 
template<typename T>
int Array<T>::size() const
{
    return (mSize);
}
 
template<typename T>
Array<T>::Array()
{
    mSize = 1;
    mElem = new T[mSize];
}
 
template<typename T>
Array<T>::Array(int size)
{
    mSize = size;
    mElem = new T[mSize];
}
 
template<typename T>
Array<T>::~Array()
{
    delete [] mElem;
}
 
template<typename T>
void Array<T>::add_new_elem(int newSize)
{
    T* newElem = new T[newSize];
 
    for(int i=0;i<newSize;i++)
        newElem[i] = mElem[i];
 
    mSize = newSize;
    delete [] mElem;
    mElem = newElem;
}
 
template<typename T>
T &Array<T>::operator[](int x) const
{
    /*if(x >= mSize || x < 0){ 
        string e = "Error";
        throw invalid_argument(e);
    }*/
    return (mElem[x]);
}
 
 
#endif

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
#include "array.h"
 
using namespace std;
 
int main()
{
    Array<int> arr,arr2;
    for(int i=0;i<8;i++){
        arr.push_back(i+1);
    }
    cout<<endl<<arr.size()<<endl<<endl;
    for(int i=0;i<arr.size();i++)
        cout<<arr[i]<<" ";
    
    system("pause>0");
    return 0;
}
0
silent_1991
Эксперт С++
4985 / 3042 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
04.02.2013, 16:45 #10
The_bolT, в конструкторе же. Вы изначально выделяете массив из одного элемента. Последующие push_back добавляют элементы, не учитывая, что один уже добавлен в конструкторе (логически его быть не должно, конструктор должен создавать "пустой" массив).
1
The_bolT
70 / 70 / 1
Регистрация: 22.01.2013
Сообщений: 231
04.02.2013, 16:54  [ТС] #11
Правда в конструкторе. Теперь все работает как я хотел! Большое спасибо!
0
alexpac26
14 / 22 / 0
Регистрация: 20.01.2013
Сообщений: 125
04.02.2013, 16:59 #12
класс vector вроде целиком и полностью сабж реализует
0
silent_1991
04.02.2013, 17:00
  #13

Не по теме:

alexpac26, я бы даже сказал, сверх того реализует. Только если не писать велосипеды, не спотыкаться на очевидных и не очень граблях - как тогда чему-нибудь научиться?

0
alexpac26
04.02.2013, 17:19
  #14

Не по теме:

ну велосипеды можно и более интересные придумать....

0
silent_1991
04.02.2013, 17:47     перегрузка []
  #15

Не по теме:

alexpac26, когда я писал свой первый Vector, мне было интересно. А уж как за List принялся...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.02.2013, 17:47
Привет! Вот еще темы с ответами:

Перегрузка ++ и -- - C++
У меня было задание: Напишите программу работы со временем, в которой используются перегруженные операции ++ и --, которые работают в...

Перегрузка << и >> - C++
помогите сделать так чтобы &lt;&lt; и &gt;&gt; в int main() работали... Printers.h class Printers { public: ...

Перегрузка в c++ - C++
Зачем нужно использовать перегрузку в c++? Этот вопрос будет у меня на экзамене, поэтому хочу услышать ваши версии

перегрузка [] - C++
Здарова никак не могу перегрузить имеется класс Int2 моделирующий int я перегрузил rvalue тоесть при вызове int a; Int2...


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

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

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