Zaawansowane CPP/Ćwiczenia 12: Używanie funktorów: Różnice pomiędzy wersjami

Z Studia Informatyczne
Przejdź do nawigacjiPrzejdź do wyszukiwania
Mirek (dyskusja | edycje)
Nie podano opisu zmian
Nie podano opisu zmian
 
(Nie pokazano 2 wersji utworzonych przez jednego użytkownika)
Linia 33: Linia 33:
  }
  }


Kod znajduje się w pliku [http://osilek.mimuw.edu.pl/images/0/08/For_each.h for_each.h].
Kod znajduje się w pliku [[media:For_each.h | for_each.h]].
</div></div>
</div></div>


{{cwiczenie|2||
{{cwiczenie|2||


Zaimplementuj opisany na wykładzie adapter, który opakowuje funkcję lub funktor, ignorując zwracaną przez nie wartość i zwracający zamiast niej jakąś wartość wybranego typu.  Np.:
Zaimplementuj opisany na wykładzie adapter, który opakowuje funkcję lub funktor, ignorując zwracaną przez nie wartość,, i zwracający zamiast niej jakąś wartość wybranego typu.  Np.:
   
   
  double f(int);
  double f(int);
Linia 48: Linia 48:
  adapt(f)(0);
  adapt(f)(0);


wywołuje <tt>f(0)</tt> i nie wraca żadnej wartości.
wywołuje <tt>f(0)</tt> i nie zwraca żadnej wartości.
}}
}}


Linia 65: Linia 65:
   result_type operator()(arg1_type a1,arg2_type a2) {_f(a1,a2);return
   result_type operator()(arg1_type a1,arg2_type a2) {_f(a1,a2);return
  result_type(_val);};
  result_type(_val);};
};
};
 
Do tego dochodzi jeszcze specjalizacja dla {Result <nowiki> =</nowiki>    void} i funkcje:
Do tego dochodzi jeszcze specjalizacja dla <tt>Result <nowiki> =</nowiki>    void</tt> i funkcje:


  template<typename R,typename F> adapt_t<F,R>
  template<typename R,typename F> adapt_t<F,R>
Linia 74: Linia 74:
  adapt(F f) {return adapt_t<F,void>(f);}
  adapt(F f) {return adapt_t<F,void>(f);}


Kod znajduje się w pliku [http://osilek.mimuw.edu.pl/images/4/45/Dev_null.h dev_null.h].
Kod znajduje się w pliku [[media:Dev_null.h | dev_null.h]].
</div></div>
</div></div>


Linia 88: Linia 88:
     void operator<nowiki> =</nowiki>  (const T&) {};
     void operator<nowiki> =</nowiki>  (const T&) {};
   };
   };
 
której operator przypisania "połyka" swój argument.
której operator przypisania "połyka" swój argument.
Kod znajduje się w pliku [http://osilek.mimuw.edu.pl/images/4/45/Dev_null.h dev_null.h].
Kod znajduje się w pliku [[media:Dev_null.h | dev_null.h]].
</div></div>
</div></div>


Linia 101: Linia 101:
<div class="mw-collapsible mw-made=collapsible mw-collapsed"><span class="mw-collapsible-toogle mw-collapsible-toogle-default style="font-variant:small-caps">Rozwiązanie</span><div class="mw-collapsible-content" style="display:none">
<div class="mw-collapsible mw-made=collapsible mw-collapsed"><span class="mw-collapsible-toogle mw-collapsible-toogle-default style="font-variant:small-caps">Rozwiązanie</span><div class="mw-collapsible-content" style="display:none">
Iterator  
Iterator  
 
  template<typename F,typename T>   
  template<typename F,typename T>   
  class exec_iterator_t: public std::iterator<std::output_iterator_tag,T>  
  class exec_iterator_t: public std::iterator<std::output_iterator_tag,T>  
  {
  {
   F _fun;
   F _fun;
 
oparty jest o zagnieżdżoną  klasę proxy:
oparty jest o zagnieżdżoną  klasę proxy:
 
  struct do_it {
  struct do_it {
     exec_iterator_t *_parent;
     exec_iterator_t *_parent;
Linia 119: Linia 119:
przekazanej. Operator <tt>*</tt> zwraca obiekt proxy, a operatory  
przekazanej. Operator <tt>*</tt> zwraca obiekt proxy, a operatory  
<tt>++</tt> nie robią nic:
<tt>++</tt> nie robią nic:
 
 
  public:
  public:
   exec_iterator_t(F fun):_fun(fun),_proxy(this) {};
   exec_iterator_t(F fun):_fun(fun),_proxy(this) {};
Linia 128: Linia 128:


Do utworzenia iteratora używamy szablon funkcji
Do utworzenia iteratora używamy szablon funkcji
 
 
  template<typename T,typename F>  
  template<typename T,typename F>  
  exec_iterator_t<F,T> exec_iterator(F f){
  exec_iterator_t<F,T> exec_iterator(F f){
Linia 136: Linia 136:
korzystając z automatycznej dedukcji typów.
korzystając z automatycznej dedukcji typów.


Kod znajduje się w pliku [http://osilek.mimuw.edu.pl/images/1/10/Exec_iterator.h exec_iterator.h].
Kod znajduje się w pliku [[media:Exec_iterator.h | exec_iterator.h]].
</div></div>
</div></div>

Aktualna wersja na dzień 10:48, 2 paź 2006

Ćwiczenie 1

Napisz algorytm for_each który działałby na dwu zakresach.

template<typename InputIterator1,
         typename InputIterator2,
         typename BinaryFunction op> 
BinaryFunction for_each(InputIterator1 first1,
                        InputIterator1 last1,
                        InputIterator2 first2,
                        BinaryFunction op);

Algorytm ma działać tak jak standardowy for_each, tyle że funkcja op ma być stosowana do par elementów:

op(*first1,*first2);
op(*(first1+1),*(first2+1);
...
Rozwiązanie

Ćwiczenie 2

Zaimplementuj opisany na wykładzie adapter, który opakowuje funkcję lub funktor, ignorując zwracaną przez nie wartość,, i zwracający zamiast niej jakąś wartość wybranego typu. Np.:

double f(int);
adapt(f,7)(0);

wywołuje f(0) i zwraca 7.

double f(int);
adapt(f)(0);

wywołuje f(0) i nie zwraca żadnej wartości.

Rozwiązanie

Ćwiczenie 3

Napisz iterator, który nic nie robi, ignorując przypisywane do niego elementy.

Rozwiązanie

Ćwiczenie 4

Zaimplementuj opisany w wykładzie iterator, który działa podaną funkcją na przypisywane obiekty.

Rozwiązanie