The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

Интерактивная система просмотра системных руководств (man-ов)

 ТемаНаборКатегория 
 
 [Cписок руководств | Печать]

back_inserter (3)
  • >> back_inserter (3) ( Solaris man: Библиотечные вызовы )
  • 
                           Standard C++ Library
                 Copyright 1998, Rogue Wave Software, Inc.
    
    
    NAME
         back_insert_iterator, back_inserter
    
          - An insert iterator used to insert items at the end  of  a
         collection.
    
    
    
    SYNOPSIS
         #include <iterator>
         template <class Container>
         class back_insert_iterator;
    
    
    
    DESCRIPTION
         Insert iterators let you insert new elements into a  collec-
         tion  rather  than copy a new element's value over the value
         of an existing element.  The  class_back_insert_iterator  is
         used  to  insert items at the end of a collection. The func-
         tion   back_inserter    creates    an    instance    of    a
         back_insert_iterator  for  a  particular  collection type. A
         back_insert_iterator can be used with vectors,  deques,  and
         lists, but not with maps or sets.
    
    
    
    INTERFACE
         template <class Container>
         class back_insert_iterator
            : public iterator <output_iterator_tag, void, void, void,
             void> {
    
         protected:
           Container* container;
         public:
           typedef Container container_type;
           explicit back_insert_iterator (Container&);
           back_insert_iterator<Container>&
            operator=
                   (const typename Container::const_reference value);
           back_insert_iterator<Container>& operator* ();
           back_insert_iterator<Container>& operator++ ();
           back_insert_iterator<Container> operator++ (int);
         };
         template <class Container>
         back_insert_iterator<Container> back_inserter (Container&);
    
    
    
    TYPES
         container_type
    
    
            The type of container acted on by this iterator.
    
    
    
    CONSTRUCTORS
         explicit
         back_insert_iterator (Container& x);
    
    
            Constructor.     Creates     an     instance     of     a
            back_insert_iterator associated with container x.
    
    
    
    OPERATORS
         back_insert_iterator<Container>&
         operator= (const typename Container::value_type& value);
    
    
            Inserts a copy of value on the end of the container,  and
            returns *this.
    
    
    
         back_insert_iterator<Container>&
         operator* ();
    
    
            Returns *this.
    
    
    
         back_insert_iterator<Container>&
         operator++ ();
         back_insert_iterator<Container>
         operator++ (int);
    
    
            Increments the input iterator and returns *this.
    
    HELPER FUNCTIONS
         template <class Container>
         back_insert_iterator<Container>
         back_inserter (Container& x)
    
    
            Returns a back_insert_iterator that inserts  elements  at
            the  end  of  container  x.  This  function allows you to
            create insert iterators inline.
    
    
    
    EXAMPLE
         //
         // ins_itr.cpp
         //
          #include <iterator>
          #include <deque>
          #include <iostream>
         using namespace std;
    
         int main ()
          {
            //
            // Initialize a deque using an array.
            //
           int arr[4] = { 3,4,7,8 };
           deque<int> d(arr+0, arr+4);
            //
            // Output the original deque.
            //
           cout << "Start with a deque: " << endl << "     ";
           copy(d.begin(), d.end(),
                ostream_iterator<int,char>(cout," "));
            //
            // Insert into the middle.
            //
           insert_iterator<deque<int> > ins(d, d.begin()+2);
            *ins = 5; *ins = 6;
            //
            // Output the new deque.
            //
           cout << endl << endl;
           cout << "Use an insert_iterator: " << endl << "     ";
           copy(d.begin(), d.end(),
                ostream_iterator<int,char>(cout," "));
            //
            // A deque of four 1s.
            //
           deque<int> d2(4, 1);
            //
            // Insert d2 at front of d.
            //
           copy(d2.begin(), d2.end(), front_inserter(d));
            //
            // Output the new deque.
            //
           cout << endl << endl;
           cout << "Use a front_inserter: " << endl << "     ";
           copy(d.begin(), d.end(),
                ostream_iterator<int,char>(cout," "));
            //
            // Insert d2 at back of d.
            //
           copy(d2.begin(), d2.end(), back_inserter(d));
            //
            // Output the new deque.
            //
           cout << endl << endl;
           cout << "Use a back_inserter: " << endl << "     ";
           copy(d.begin(), d.end(),
                ostream_iterator<int,char>(cout," "));
           cout << endl;
    
           return 0;
          }
    
         Program Output
    
    
    
         Start with a deque:
             3 4 7 8
         Use an insert_iterator:
             3 4 5 6 7 8
         Use a front_inserter:
             1 1 1 1 3 4 5 6 7 8
         Use a back_inserter:
             1 1 1 1 3 4 5 6 7 8 1 1 1 1
    
    
    
    WARNINGS
         If your compiler does not support default  template  parame-
         ters,  then you always need to supply the Allocator template
         argument. For instance, you have to write:
    
         vector<int,allocator<int> >
    
         instead of:
         vector<int>
    
         If your compiler does not support namespaces,  then  you  do
         not need the using declaration for std.
    
    
    
    SEE ALSO
         Insert_Iterators
    
    
    
    


    Поиск по тексту MAN-ов: 




    Партнёры:
    PostgresPro
    Inferno Solutions
    Hosting by Hoster.ru
    Хостинг:

    Закладки на сайте
    Проследить за страницей
    Created 1996-2025 by Maxim Chirkov
    Добавить, Поддержать, Вебмастеру