Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/21: Рейтинг темы: голосов - 21, средняя оценка - 4.57
1 / 1 / 0
Регистрация: 19.03.2014
Сообщений: 22

Наследование стандартного итератора

31.08.2015, 11:35. Показов 4154. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день! Хочу сделать класс "Фильтрующий Итератор" - наследованный от std::vector<int>::iterator, который будет перечислять только положительные элементы массива, а отрицательные пропускать. В классе содержится внутреннее поле типа std::vector<int>::iterator. Операция инкремента перегружена так: внутреннее поле инкрементируется, затем разыменовывается и смотрим, если значение меньше нуля, то продолжаем инкрементироваться, пока оно не станет больше нуля. Вопрос такой: как понять, что мы вышли за пределы end и хватит уже инкрементироваться, а пора вернуть end?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.08.2015, 11:35
Ответы с готовыми решениями:

Наследование стиля от стандартного компонента wpf, к созданому мной
Добрый вечер! Я создал два компанента: public class MyNode : TreeViewItem { //... } public class MyTree : TreeView

Тело метода не может быть блоком итератора, так как "void" не является типом интерфейса итератора
using UnityEngine; using UnityEngine.UI; using System.Collections.Generic; using System.Collections; using System; public...

Валидность итератора
Допустимо ли делать такие проверки? Код то отрабатывает, но можно ли так делать? std::vector&lt;int&gt; vec = {1, 2, 3, 4, 5}; auto...

4
В астрале
Эксперт С++
 Аватар для ForEveR
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562
31.08.2015, 11:37
q0o0p, Хранить сигнальный итератор (vector.end()). Не стоит наследоваться от итератора вектора, лучше напишите свой или используйте boost::iterator_facade.
1
196 / 197 / 120
Регистрация: 27.05.2011
Сообщений: 545
31.08.2015, 11:43
Я бы не наследовался от std::vector<int>::iterator, а создал бы независимый итератор. Потому что это уже получится двунаправленный итератор, а не итератор последовательного доступа. По крайней мере, мне так кажется, что так будет лучше.

Сам итератор у меня хранил бы ссылку на контейнер и копию оригинального итератора.
1
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
31.08.2015, 11:50
Цитата Сообщение от q0o0p Посмотреть сообщение
Добрый день! Хочу сделать класс "Фильтрующий Итератор"
пример подобного рода всяческой кастомизации:
http://www.cplusplus.com/refer... _inserter/

обратите внимание:
кастомизация логики работы с уже существующими итераторами,
осуществляется без необходимости вмешиваться в логику уже существующих.
1
В астрале
Эксперт С++
 Аватар для ForEveR
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562
31.08.2015, 12:09
Пример:
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
#include <iostream>
#include <vector>
#include <boost/iterator/iterator_adaptor.hpp>
 
template<typename Predicate, typename Iterator>
struct filter_iterator : 
   public boost::iterators::iterator_adaptor
   <
      filter_iterator<Predicate, Iterator>,
      Iterator
   >
{
   friend class boost::iterators::iterator_core_access;
   typedef boost::iterators::iterator_adaptor
   <
      filter_iterator<Predicate, Iterator>,
      Iterator
   > base_type;
public:
   filter_iterator(Predicate p, Iterator b, Iterator e) :
      base_type(b), pred(p), end(e)
   {
      satisfy_predicate();
   }
private:
   void increment()
   {
      ++(this->base_reference());
      satisfy_predicate();
   }
 
   /*void decrement()
   {
      while (!pred(*--(this->base_reference())));
   }*/
 
   void satisfy_predicate()
   {
      while (this->base() != end && !pred(*this->base()))
      {
         ++(this->base_reference());
      }
   }
 
   Predicate pred;
   Iterator end;
};
 
template<typename Predicate, typename Iterator>
filter_iterator<Predicate, Iterator> make_filter_iterator(const Predicate& pred, const Iterator& b, const Iterator& e)
{
   return filter_iterator<Predicate, Iterator>(pred, b, e);
}
использование:

C++
1
2
3
4
5
6
7
8
9
10
11
12
int main()
{
   std::vector<int> v = {-1,2,3,-4,5};
   auto pred = [](int v) { return v > 0; };
   auto f_begin = make_filter_iterator(pred, v.begin(), v.end()),
        f_end = make_filter_iterator(pred, v.end(), v.end());
   while (f_begin != f_end)
   {
      std::cout << *f_begin << std::endl;
      ++f_begin;
   }
}
3
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.08.2015, 12:09
Помогаю со студенческими работами здесь

Переопределение итератора
Здравствуйте. По заданию нужно создать свою коллекцию, класс наследует интерфейс Collection. Помогите пожалуйста с переопределением метода...

Создание итератора
Привет всем. Хочу для своей коллекции HashTable реализовать цикл for-each, чтобы просматривать ее. Есть некий класс object, объекты...

Разыменование итератора
Делаю предикат-функцию поиска внутри вектора,состоящего из экземпляров класса.Решил использовать итераторы.То есть мне нужно обратиться к...

Проверка итератора
как проверить указывает ли на что либо итератор или он уже неправильный?

Методы итератора
подскажите как реализовать метод итератора public E next() в массиве списков?


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru