Zaawansowane CPP/Ćwiczenia 11: Funktory: Różnice pomiędzy wersjami
Z Studia Informatyczne
Przejdź do nawigacjiPrzejdź do wyszukiwania
Nie podano opisu zmian |
Nie podano opisu zmian |
||
Linia 133: | Linia 133: | ||
}; | }; | ||
result_type call(A1 a1,A2 a2, | result_type call(A1 a1,A2 a2, | ||
std::unary_function<arg1_type,result_type>) { | <nowiki>std::unary_function<arg1_type,result_type>) {</nowiki> | ||
return _f(a1); | return _f(a1); | ||
}; | }; | ||
Linia 159: | Linia 159: | ||
Całość kodu znajduje się w pliku [http://osilek.mimuw.edu.pl/images/7/7d/Call.h call.h]. | Całość kodu znajduje się w pliku [http://osilek.mimuw.edu.pl/images/7/7d/Call.h call.h]. | ||
Implementując adapter | Implementując adapter <tt>macro</tt> musimy umieć poznać która z dwu przekazanych funkcji ma wiecej argumentów. Używamy w tym celu szablonu <tt>If_then_else</tt>: | ||
funkcji ma wiecej argumentów. Używamy w tym celu szablonu <tt>If_then_else</tt>: | |||
template<typename F1,typename F2> struct macro_type { | template<typename F1,typename F2> struct macro_type { |
Wersja z 11:04, 25 wrz 2006
Ćwiczenie 1
Zaimplementuj adapter compose_f_gx_hy
realizujący złożenie dwuargumentowe .
Rozwiązanie
Ćwiczenie 2
Korzystając z klasy functor_traits
zaimplementuj adpter bind1st
, który bedzie działał zarówno dla funktorów jedno-, jak i dwuargumentowych.
Rozwiązanie
Ćwiczenie 3
Zaimplementuj funktor implementujący, składanie funkcji poprzez wykonywanie ich po kolei np.:
macro(f1,f2)(x)
powinno wykonać
f1(x);f2(x);
Wartości zwracane przez te funkcje są ignorowane. Funkcja macro powinna zwracać funktor odpowiedniego typu (posiadający odpowiednie typy stowarzyszone) tak, aby możliwe było dalsze składanie np.:
macro(macro(f1,f2),f3)(x)
powinno wywołać:
f1(x);f2(x);f3(x);
Rozwiązanie
Ćwiczenie 4
Zmodyfikuj powyższy szablon tak aby można było mieszać funkcje o różnej liczbie agrgumentów np.:
int f(); void g(double); void h(double,int);
macro(f,g)(x);
powinno wywołać
f();g(x)}
a
macro(g,h)(3.14,0);
powinno wywołać
g(3.14);h(3.14,0)
Podpowiedź
Rozwiązanie