Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
Эксперт С++
177 / 163 / 21
Регистрация: 12.02.2013
Сообщений: 410
1

Operator[] и const map

19.02.2015, 12:36. Просмотров 1853. Ответов 10
Метки нет (Все метки)

Привет всем!
Что за фигня? Оператор доступа по индексу не работает с константной мапой! Обнаружил, когда написал константную функцию для класса, в котором есть мапа, из которой функция должна была вернуть один из элементов. Это нормально вообще??? Ведь классика перегрузки данного оператора подразумевает наличие двух:
C++
1
2
const T& operator[] (int i) const;
T& operator[] (int i);
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.02.2015, 12:36
Ответы с готовыми решениями:

char operator[](unsigned short offset) const; // что означает const?
Собстенно вопрос уже озвучен :).

Что это bool operator== (const CLASS&) const;
Что это? class CLASS { public: bool operator== (const CLASS&) const; ...

Вызов operator[] через operator[] const
Перелистывал Майерса, наткнулся на код, подскажите пожалуйста почему он советует закомментированный...

error: invalid operands of types 'const int*' and 'const int*' to binary 'operator+'
Что означает ошибка в 8 строчке error: invalid operands of types 'const int*' and 'const int*' to...

10
Ушел с форума
Эксперт С++
16406 / 7381 / 1184
Регистрация: 02.05.2013
Сообщений: 11,637
Записей в блоге: 1
19.02.2015, 12:44 2
Ждем минимальный код, воспроизводящий проблему.
0
2683 / 1855 / 552
Регистрация: 05.06.2014
Сообщений: 5,347
19.02.2015, 12:45 3
Цитата Сообщение от ITcrusader Посмотреть сообщение
Что за фигня? Оператор доступа по индексу не работает с константной мапой!
Оператор доступа по индексу предполагает автоматическое создание не существующих в мапе элементов. Потому и не работает - как он в константе чего-то создавать будет? Хотя да, по уму должен был бы работать и с константной мапой, плюясь в случае чего исключениями.
2
Эксперт С++
177 / 163 / 21
Регистрация: 12.02.2013
Сообщений: 410
19.02.2015, 12:50  [ТС] 4
А легко:

Так - нормально:
C++
1
2
    map<int, int> m;
    m[1]; // норм
Так - нет:
C++
1
2
    const map<int, int> m;
    m[1]; // не норм
Добавлено через 3 минуты
Renji, да, действительно, он же еще функцию вставки выполняет. Вопрос снят. Неудобно это, однако.
0
Эксперт С++
8226 / 3814 / 826
Регистрация: 15.11.2014
Сообщений: 8,663
19.02.2015, 12:54 5
Цитата Сообщение от ITcrusader Посмотреть сообщение
Что за фигня?
C++
1
2
mymap["ololo"]; //<--- что должно произойти с картой, 
    //если элемента с ключем ещё не существовало?
Будет создан новый элемент.

Благодаря этому мы можем написать так:

C++
1
mymap["ololo"] = value;
Вопрос: но если у вас константный, то бишь, не изменяемый контейнер,
то какого черта должен в этом случае делать operator[] ?

Добавлено через 1 минуту
Цитата Сообщение от ITcrusader Посмотреть сообщение
Неудобно это, однако.
Откройте для себя std::map::at
http://www.cplusplus.com/reference/map/map/at/
1
Эксперт С++
177 / 163 / 21
Регистрация: 12.02.2013
Сообщений: 410
19.02.2015, 12:56  [ТС] 6
Цитата Сообщение от hoggy Посмотреть сообщение
то какого черта должен в этом случае делать operator[] ?
Лааадно, лааадно, и так стыдно) Я как-то совсем забыл о дополнительной семантике этого оператора для мапы=)

Добавлено через 1 минуту
Цитата Сообщение от hoggy Посмотреть сообщение
Откройте для себя std::map::at
О, огонь!
0
Эксперт С++
3056 / 1398 / 421
Регистрация: 19.01.2009
Сообщений: 3,763
19.02.2015, 13:00 7
ITcrusader, если нужно проверить существует ли элемент в std::map с указанным ключом, то пользуйте std::map<K,T>::count(). Если нужно получить значение по указанному ключу без исключений в случае его отсутствия, то используйте std::map<K, T>::find().
1
Эксперт С++
177 / 163 / 21
Регистрация: 12.02.2013
Сообщений: 410
19.02.2015, 13:07  [ТС] 8
schdub, Да, без исключений даже лучше, я при получении точно знаю, что он там есть
0
Эксперт С++
8226 / 3814 / 826
Регистрация: 15.11.2014
Сообщений: 8,663
19.02.2015, 13:13 9
Цитата Сообщение от schdub Посмотреть сообщение
ITcrusader, если нужно проверить существует ли элемент в std::map с указанным ключом, то пользуйте std::map<K,T>::count(). Если нужно получить значение по указанному ключу без исключений в случае его отсутствия, то используйте std::map<K, T>::find().
ITcrusader, если нужно получить доступ к элементу,
то std::map<K, T>::find() достаточно и для проверки существования, и для получения значения.

Использование std::map<K,T>::count() в этом случае избыточно.
1
Эксперт С++
3056 / 1398 / 421
Регистрация: 19.01.2009
Сообщений: 3,763
19.02.2015, 13:19 10
hoggy, согласен с вами. Я упомянул про count() если нужно только проверить есть ли указанный ключ в map и не хочется писать много кода.
1
Эксперт С++
177 / 163 / 21
Регистрация: 12.02.2013
Сообщений: 410
19.02.2015, 13:23  [ТС] 11
Спасибо, господа, привык пользоваться оператором[] =) Для моих нужд в контексте константности мапы и 100%-го наличия там получаемого элемента лучше всего подойдет find.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.02.2015, 13:23

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

Map. operator[]
#include &lt;iostream&gt; #include &lt;string&gt; #include &lt;map&gt; #include &lt;fstream&gt; using namespace std;...

Объясните, как исправить ошибку invalid operands of types 'double' and 'const char [2]' to binary 'operator -
#include &lt;stdio.h&gt; #include &lt;math.h&gt; #include &lt;iostream&gt; #include &lt;cmath&gt; using namespace...

int const * const foo(const int* param) const - разъясните значение квалификаторов
int const * const foo(const int* param) const -----1------2----------3----------------4 1: ?...

Структура как ключ map, возможно ли как-то реализовать operator []
Возможно бред, но всё же. Реализовать сам ключ не сложно, вот код: class cKey { public: ...


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

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

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