Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> iterator и const_iterator без дублирования кода 
:(
    Опции темы
User008
Дата 22.4.2012, 15:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 306
Регистрация: 9.9.2009

Репутация: 1
Всего: 1



X::const_iterator X::f(T t) const и X::iterator X::f(T t)
Как такое реализуют без дублирования кода?

Это сообщение отредактировал(а) User008 - 22.4.2012, 15:36
PM MAIL   Вверх
mes
Дата 22.4.2012, 16:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


любитель
****


Профиль
Группа: Участник Клуба
Сообщений: 7954
Регистрация: 14.1.2006

Репутация: 144
Всего: 250



Цитата(User008 @  22.4.2012,  14:35 Найти цитируемый пост)
Как такое реализуют без дублирования кода?

никак... если внутри сложная логика - ее выносят, все остальное остается..


--------------------
PM MAIL WWW   Вверх
User008
Дата 22.4.2012, 16:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 306
Регистрация: 9.9.2009

Репутация: 1
Всего: 1



Цитата(mes @ 22.4.2012,  16:25)
Цитата(User008 @  22.4.2012,  14:35 Найти цитируемый пост)
Как такое реализуют без дублирования кода?

никак... если внутри сложная логика - ее выносят, все остальное остается..

Спасибо за ответ. Существуют ли ещё мнения?
PM MAIL   Вверх
boostcoder
Дата 22.4.2012, 16:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


pattern`щик
****


Профиль
Группа: Завсегдатай
Сообщений: 5458
Регистрация: 1.4.2010

Репутация: 49
Всего: 110



можно реализовать только "X::const_iterator X::f(T t) const", и используя const_cast, вызывать ее из "X::iterator X::f(T t)".
 smile 
PM WWW   Вверх
maxim1000
Дата 22.4.2012, 22:26 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник
Сообщений: 3334
Регистрация: 11.1.2003
Где: Киев

Репутация: 17
Всего: 110



один раз довелось такое делать

в том случае отличий было немного - в основном, в типах

поэтому отличающиеся типы я вынес в переметры шаблона, а оба итератора сделал typedef'ами с соответствующими параметрами

для того, чтобы неконстантный итератор мог автоматически преобразовываться в константный, я сделал у шалонного итератора конструктор из неконстантного - для константного это нужное преобразование, а для неконстантного конструктор копирования


--------------------
qqq
PM WWW   Вверх
bsa
Дата 24.4.2012, 12:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Модератор
Сообщений: 9185
Регистрация: 6.4.2006
Где: Москва, Россия

Репутация: 63
Всего: 196



Имхо, если логика совпадает, то можно неконстантный сделать через константный используя const_cast.
Другой вариант, можно сократить количество дублирующегося кода до минимума, вынеся всю константную логику в отдельный приватный метод (например, поиск нужного элемента по базе)
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1156 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.