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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.92
dead_santa
0 / 0 / 0
Регистрация: 12.09.2009
Сообщений: 5
#1

Одновременная реализация константного и неконстантного оператора [] в классе string - C++

12.09.2009, 22:00. Просмотров 1623. Ответов 6
Метки нет (Все метки)

Вобщем, проблема в следующем: нужно реализовать обращение по индексу в классе string двумя вариантами оператора []: константный (для чтения) и возвращающий char& для изменения. Со вторым оператором я вроде разобрался. А вот как первый реализовать, и ,чтобы, когда надо было прочитать, включался первый оператор?. Я смог добиться написания обоих - т.е. компилятор не ругается, что у двух методов одинаковые аргументы, однако, при пошаговом рассмотрении программы, когда нужно просто обратиться, ничего не меня, (printf("%c", a[0]); ) компьютер упорно заходит в метод char& operator []( int index).Прилагаю код программы, пишу в Visual Studio 2005. Заранее спасибо.
П.С.: Тут есть "левые" функции, но они нужны для других заданий. Буду рад, если поможете с вопросами в комментариях.

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
#include <stdio.h>
#include <string.h>
 
class string{
    char* data;
public: 
    int length()const{
        return strlen(data);
    }
    string(){ 
        data = new char[1];
        data[0] = '\0';
    }
    string(char *s) {  
        data = new char[strlen(s) + 1];
        ::strcpy(data, s);
    }
    string(const string &s){
        data = new char[s.length()+1];
        ::strcpy(data, s.data); 
    }
    ~string(){
        delete[] data;
    }   
    string &operator =(const string &s){
        if (data){
            delete[] data;
            data = new char[s.length() + 1];
            ::strcpy(data, s.data);
        }
        return *this;
    }
 
 
    /*string &operator =(const string &s){
        if(&s==this)
            return *this;
        if (data)
            delete[] data;
        if (s.data){
            data=new char[s.length()+1];
            ::strcpy(data, s.data);
        }
        else 
            data='\0';
        return *this;
    }*/
 
    operator const char*(){
        return (const char*)data;
    }
    string operator +(const string &s)const{ 
        char *buff = new char[s.length() + length() + 1]; 
        ::strcpy(buff, data); 
        ::strcat(buff, s.data); 
        string rez( buff ); 
        delete[] buff;
        return rez; 
    }
    string operator +=(const string &s){ 
        char *buff=new char[s.length()+length()+1]; 
        ::strcpy(buff, data); 
        ::strcat(buff, s.data);
        int pro=length();
        delete[] data;
        data=new char[s.length()+pro+1];
        data=buff;//Как очистить buff?? Если написать delete[] buff *this'ом будет возвращаться пустой buff
        return *this;       
    }
    const char& operator [](int index) const{
        if((index<0)||(index>length())){
            printf("Neverni indeks (indeks=%d)\n", index);
            return data[0];//Что возвращать? Хотел EOF, не даёт... Ну, думаю, и так можно оставить, просто не знаю, что программисты в таких случаях возвращают :)
        }
        else
            return data[index];
    }
    char& operator []( int index){
        if((index<0)||(index>length())){
            printf("Neverni indeks (indeks=%d)\n", index);
            return data[0];//Что возвращать? Хотел EOF, не даёт... Ну, думаю, и так можно оставить, просто не знаю, что программисты в таких случаях возвращают :)
        }
        else
            return data[index];
    }   
};
 
int main(){     
    string a("Hello!");
    (const char*)a;
    a[0]='Z';
    printf("%c", a[0]);
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.09.2009, 22:00
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Одновременная реализация константного и неконстантного оператора [] в классе string (C++):

У меня класс B в классе A, а в классе B рекурсивная функция переопределения оператора "()", как её вызвать, не создавая явно объект класса B? - C++
#include &lt;windows.h&gt; #include &lt;iostream&gt; using namespace std; //Вот главный класс class A{ public: A (){}; class...

Перегрузка оператора '=' в классе - C++
#include &lt;iostream&gt; #include &lt;cstring&gt; using std::cout; using std::endl; class CMessage { public: ...

Переопределение оператора в классе - C++
class String { char *mData; static const int c_size = 100; String(); String &amp; operator+=(const String &amp; s) { ...

Перегрузка оператора ==, в классе Матрица - C++
#ifndef MATRIX_H #define MATRIX_H template &lt;class T&gt; class Matrix { public: Matrix(int Rows, int Cols); ~Matrix(); ...

Вызов оператора= в производном классе - C++
#include &lt;iostream&gt; #include &lt;vector&gt; #include &lt;numeric&gt; using namespace std; template &lt;class T&gt; class Vector: public...

Перегрузка бинарного оператора << в template классе - C++
Помогите пожалйста люди! не получается перегрузить оператор &gt;&gt; и &lt;&lt; в шаблонном классе выдает ошибку: error C2804: бинарный 'operator...

6
zim22
depict1
276 / 141 / 2
Регистрация: 11.07.2009
Сообщений: 606
12.09.2009, 22:26 #2
посмотри в MSDN как реализованы две версии operator[] для класса вектор и сделай также.
1
dead_santa
0 / 0 / 0
Регистрация: 12.09.2009
Сообщений: 5
13.09.2009, 10:39  [ТС] #3
Смотрел... Возникает вопросы то ли лыжи не едут, то ли я....
Вот как в MSDN реализовано:
C++
1
2
3
4
5
6
reference operator[](
   size_type _Pos
);
const_reference operator[](
   size_type _Pos
) const;
Вот как у меня:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
const char& operator [](int index) const{
        if((index<0)||(index>length())){
            printf("Neverni indeks (indeks=%d)\n", index);
            return data[0];//Что возвращать? Хотел EOF, не даёт... Ну, думаю, и так можно оставить, просто не знаю, что программисты в таких случаях возвращают :)
        }
        else
            return data[index];
    }
    char& operator []( int index){
        if((index<0)||(index>length())){
            printf("Neverni indeks (indeks=%d)\n", index);
            return data[0];//Что возвращать? Хотел EOF, не даёт... Ну, думаю, и так можно оставить, просто не знаю, что программисты в таких случаях возвращают :)
        }
        else
            return data[index];
    }
Вроде по образцу...

Добавлено через 12 минут
Нашёл даже для класса stirng пример:
C++
1
2
const char& operator[] ( size_t pos ) const;
      char& operator[] ( size_t pos );
Может я функцию для обращения неправильно вызываю? Меня смущает второе написание const, для +(конкатенации строк) - понятно зачем, а тут?
0
Rififi
2359 / 1052 / 44
Регистрация: 03.05.2009
Сообщений: 2,656
13.09.2009, 12:27 #4
при пошаговом рассмотрении программы, когда нужно просто обратиться, ничего не меня, (printf("%c", a[0]); ) компьютер упорно заходит в метод char& operator []( int index).
константная функция будет вызвана в случае константного объекта.
1
dead_santa
0 / 0 / 0
Регистрация: 12.09.2009
Сообщений: 5
13.09.2009, 17:14  [ТС] #5
Так я специально преобразовываю в const char*:
C++
1
(const char*)a;
Или что-то не то?
0
Rififi
2359 / 1052 / 44
Регистрация: 03.05.2009
Сообщений: 2,656
13.09.2009, 22:37 #6
dead_santa,

вот это -

(const char*)a;

вызывает перегруженный оператор приведения к типу const char*, который возвращает какие-то внутренние данные. результат вызова теряется (не используется), сам объект никак не изменяется.

string a("123"); // обычный объект, который может менять своё внутреннее состояние
const string b("456"); // константный объект
1
dead_santa
0 / 0 / 0
Регистрация: 12.09.2009
Сообщений: 5
14.09.2009, 05:34  [ТС] #7
Всем спасибо, что помогли
0
14.09.2009, 05:34
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.09.2009, 05:34
Привет! Вот еще темы с ответами:

По поводу потока и перегрузки оператора вставки в классе - C++
#include &lt;iostream&gt; using namespace std; class three_d { public: int x, y, z; three_d(int a, int b, int c) { x=a; y=b; z=c; } ...

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

Реализовать перегрузку оператора ввода в классе-наследнике - C++
вопрос, наверное, глупый. Есть класс, содержащий массив (размер задется пользователем) и наследник (4 элемента). Можно ли вызвать...

Перегрузка оператора индексации в одном классе и использование в другом - C++
Вообщем проблема состоит в том, что не понимаю как это сделать. Есть класс Document в нем есть вектор vec состоящий из Item'ов. В классе...


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

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

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