![]() |
![]() ![]() ![]() ![]() |
![]() |
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.
:: Главная :: ::
реклама |