Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
Разработка программного обеспечения

Indirect Iterator

Boost , ,

Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

Indirect Iterator

Author: Дэвид Абрахамс, Джереми Сиек, Томас Витт
Contact: Типы членов indirect_iterator определены согласно следующему псевдокоду, где V iterator_traits::value_type

if (Value is use_default) then
    typedef remove_const<pointee<V>::type>::type value_type;
else
    typedef remove_const<Value>::type value_type;
if (Reference is use_default) then
    if (Value is use_default) then
        typedef indirect_reference<V>::type reference;
    else
        typedef Value& reference;
else
    typedef Reference reference;
if (Value is use_default) then
    typedef pointee<V>::type* pointer;
else
    typedef Value* pointer;
if (Difference is use_default)
    typedef iterator_traits<Iterator>::difference_type difference_type;
else
    typedef Difference difference_type;
if (CategoryOrTraversal is use_default)
    typedef iterator-category (
        iterator_traversal<Iterator>::type,``reference``,``value_type``
    ) iterator_category;
else
    typedef iterator-category (
        CategoryOrTraversal,``reference``,``value_type``
    ) iterator_category;

indirect_iterator requirements

Выражение *v, где v является объектом iterator_traits::value_type, должно быть действительным выражением и конвертируемым к reference. Установщик должен моделировать концепцию траверсии, указанную iterator_category. Value, Reference, и Difference должен быть выбран таким образом, чтобы _ value, reference и differ_type отвечал требованиям >>.

[Примечание: существуют дополнительные требования к параметру iterator_traits::value_type, если параметр Value не use_default, как подразумевается алгоритм для вывода по умолчанию для value_type.]

indirect_iterator models

В дополнение к концепциям, указанным iterator_category и iterator_traversal::type, специализация indirect_iterator модели следующие понятия, где v является объектом iterator_traits::value_type:

  • Читаемый итератор, еслиссылка (*v)конвертируется взначение_тип.
  • Записываемый итератор, еслиссылка (*v)=tявляется действительным выражением (гдеtявляется объектом типа)direct_iterator::value_type
  • Lvalue Iterator, еслиссылкаявляется эталонным типом.

indirect_iterator работает с indirect_iterator, если и только X работает с Y.

indirect_iterator operations

В дополнение к операциям, требуемым описанными выше понятиями, специализация indirect_iterator обеспечивает следующие операции.

indirect_iterator();

Requires:Iterator must be Default Constructible.
Effects:Constructs an instance of indirect_iterator with a default-constructed m_iterator.

indirect_iterator(Iterator x);

Effects:Constructs an instance of indirect_iterator with m_iterator copy constructed from x.
template <
    class Iterator2, class Value2, unsigned Access, class Traversal
  , class Reference2, class Difference2
>
indirect_iterator(
    indirect_iterator<
         Iterator2, Value2, Access, Traversal, Reference2, Difference2
    > const& y
  , typename enable_if_convertible<Iterator2, Iterator>::type* = 0 // exposition
);
Requires:Iterator2 is implicitly convertible to Iterator.
Effects:Constructs an instance of indirect_iterator whose m_iterator subobject is constructed from y.base().

Тенератор const& base() const;

Returns:m_iterator

reference оператор*() const;

Returns:**m_iterator

indirect_iterator& operator++();

Effects:++m_iterator
Returns:*this

indirect_iterator& operator--();

Effects:--m_iterator
Returns:*this

Example

Этот пример печатает массив символов, используя indirect_iterator для доступа к массиву символов через массив указателей. Следующий indirect_iterator используется с алгоритмом transform для копирования символов (с увеличением одного) на другой массив. Для источника используется постоянный косвенный итератор, а для назначения используется непрямой итератор. Последняя часть примера печатает оригинальный массив символов, но на этот раз с помощью функции помощника make_indirect_iterator.

char characters[] = "abcdefg";
const int N = sizeof(characters)/sizeof(char) - 1; // -1 since characters has a null char
char* pointers_to_chars[N];                        // at the end.
for (int i = 0; i < N; ++i)
  pointers_to_chars[i] = &characters[i];
// Example of using indirect_iterator
boost::indirect_iterator<char**, char>
  indirect_first(pointers_to_chars), indirect_last(pointers_to_chars + N);
std::copy(indirect_first, indirect_last, std::ostream_iterator<char>(std::cout, ","));
std::cout << std::endl;
// Example of making mutable and constant indirect iterators
char mutable_characters[N];
char* pointers_to_mutable_chars[N];
for (int j = 0; j < N; ++j)
  pointers_to_mutable_chars[j] = &mutable_characters[j];
boost::indirect_iterator<char* const*> mutable_indirect_first(pointers_to_mutable_chars),
  mutable_indirect_last(pointers_to_mutable_chars + N);
boost::indirect_iterator<char* const*, char const> const_indirect_first(pointers_to_chars),
  const_indirect_last(pointers_to_chars + N);
std::transform(const_indirect_first, const_indirect_last,
               mutable_indirect_first, std::bind1st(std::plus<char>(), 1));
std::copy(mutable_indirect_first, mutable_indirect_last,
          std::ostream_iterator<char>(std::cout, ","));
std::cout << std::endl;
// Example of using make_indirect_iterator()
std::copy(boost::make_indirect_iterator(pointers_to_chars),
          boost::make_indirect_iterator(pointers_to_chars + N),
          std::ostream_iterator<char>(std::cout, ","));
std::cout << std::endl;

Вывод:

a,b,c,d,e,f,g,
b,c,d,e,f,g,h,
a,b,c,d,e,f,g,

Исходный код для этого примера можно найти здесь.

Статья Indirect Iterator раздела может быть полезна для разработчиков на c++ и boost.




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.



:: Главная :: ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-08-30 11:47:00
2025-07-05 02:18:05/0.0040819644927979/0