![]() |
![]() ![]() ![]() ![]() ![]() |
![]() |
Boost , ,
|
Author: | Дин Майкл Беррис |
---|---|
License: | Distributed under the Boost Software License, Version 1.0 (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) |
Функциональный итератор позволяет создавать итераторы, которые инкапсулируют объект нулевой функции и объект состояния, который отслеживает количество раз, когда итератор был увеличен. Функциональный итератор ввода моделирует концепцию InputIterator и полезен для создания ограниченных итераторов ввода.
Как и итератор генератора, итератор ввода функции принимает функцию, которая моделирует концепцию Генератор (которая в основном является нулевым или 0-аритетным объектом функции). Каждое приращение функции Функция ввода Итератора вызывает функцию генератора и сохраняет значение в итераторе. Когда итератор отменяется, сохраненное значение возвращается.
Функциональный итератор ввода инкапсулирует объект состояния, который моделирует Incrementable Concept и EqualityComparable Концепция. Эти концепции описываются ниже как:
Тип моделирует концепцию Incrementable, когда она поддерживает операторов до и после увеличения. Для данного объекта i с типом I должны действовать следующие конструкции:
Construct Description Return Type | ||
i++ | После увеличения i. | I |
++i | Предварительное увеличение i. | I& |
ПРИМЕЧАНИЕ: Дополнительный тип также должен быть Конструктивный по умолчанию .
namespace { template <class Function, class State> class function_input_iterator; template <class Function, class State> typename function_input_iterator<Function, State> make_function_input_iterator(Function & f); struct infinite; }
Класс Функциональный итератор ввода принимает два параметра шаблона Функция и Государство. Эти два параметра шаблона сообщают итератору ввода функции тип функции для инкапсуляции и тип значения внутреннего состояния для удержания.
Параметр Государство важен в тех случаях, когда необходимо контролировать тип счетчика, который определяет, находятся ли два итератора в одном состоянии. Это позволяет создать пару итераторов, которые связывают диапазон вызовов инкапсулированных функций.
Следующий пример показывает, как мы используем класс итераторов ввода функций в тех случаях, когда мы хотим создать ограниченные (ленивые) генерируемые диапазоны.
struct generator { typedef int result_type; generator() { srand(time(0)); } result_type operator() () const { return rand(); } }; int main(int argc, char * argv[]) { generator f; copy( make_function_input_iterator(f, 0), make_function_input_iterator(f, 10), ostream_iterator<int>(cout, " ") ); return 0; }
Здесь мы видим, что мы ограничили количество вызовов, используя int, которое рассчитывается от 0 до 10. Скажем, мы хотим создать бесконечный поток случайных чисел и инкапсулировать, что в паре целых чисел мы можем сделать это с помощью boost::infinite Класс помощников.
copy( make_function_input_iterator(f,infinite()), make_function_input_iterator(f,infinite()), ostream_iterator<int>(count, " ") );
Выше, вместо создания огромного вектора, мы полагаемся на алгоритм копирования STL, чтобы пройти через итератор ввода функции и назвать объект функции f, поскольку он увеличивает итератор. Особым свойством boost::infinite является то, что приравнивание двух экземпляров всегда дает ложный результат, и что приращение экземпляра boost::infinite ничего не делает. Это эффективный способ заявить, что диапазон итераторов, предоставляемый двумя итераторами с инкапсулированным бесконечным состоянием, определенно будет бесконечным.
Статья раздела может быть полезна для разработчиков на c++ и boost.
Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.
:: Главная :: ::
реклама |