Aktywne Wpisy
McBreed +197
Mała aktualizacja apropos wyjazdu do Legii cudzoziemskiej, wołam pulsujących poprzedni post.
A więc tak, wczoraj byłem pod centrum rekrutacyjnym, kręciłem się, coś zjadłem i postanowiłem, że uderzam. #!$%@?, drzwi zamknięte. Próbowałem się tam dodzwonić, ale mój e-sim pozwala tylko na internet, no nieważne.
Po drugiej stronie tego obiektu były bramki, więc wyskoczyłem do jakiejś dwójki zaskoczonych Francuzów, którzy opuszczali obiekt i zapytałem moim angielsko - francuskim, jak mam się dostać do tego
A więc tak, wczoraj byłem pod centrum rekrutacyjnym, kręciłem się, coś zjadłem i postanowiłem, że uderzam. #!$%@?, drzwi zamknięte. Próbowałem się tam dodzwonić, ale mój e-sim pozwala tylko na internet, no nieważne.
Po drugiej stronie tego obiektu były bramki, więc wyskoczyłem do jakiejś dwójki zaskoczonych Francuzów, którzy opuszczali obiekt i zapytałem moim angielsko - francuskim, jak mam się dostać do tego
3x32 +43
Aktywne Znaleziska
Zawiera treści 18+
Ta treść została oznaczona jako materiał kontrowersyjny lub dla dorosłych.
std::vector<sharedptr<Object>> tab;
i teraz chcę wyszukać obiekt po jednym z jego atrybutów
std::findif(tab.begin(), tab.end(), [](){});
To co chcę osiągnąć to:
std::findif(tab.begin(), tab.end(), [](const Object& obj){return obj.atr == 3;});
Problem polega na tym, że najpierw musiałaby nastąpić dereferencja pointera. Da się to jakoś zrobić?
Czy lambda musi przyjmować const std::shared_prt<Object>& ?
#cpp
std::shared_ptr<Object>
i taki musi być argument.Może wyglądać np. tak:
[](const std::shared_ptr<Object> &ptr) {return ptr->atr == 3;}
T
, a który będzie zwracał funktor akceptującyU
, gdzie dereferencjaU
będzie dawaćT
. wtedy będzie można użyć tego mniej więcej takstd::find_if(tab.begin(), tab.end(), withDeref([](const Object& obj){return obj.atr == 3;}));
przykładowy jednolinijkowy adapter w c++17(ofc można dorzucić tam perfect forwarding, ale to troche skomplikowane przy capture)
constexpr auto withDeref = [](auto& functor){return [functor](const auto& dereferencable){return functor(*dereferencable);};
boost::find_if(tab | boost::adaptors::indirected, [](const Object& obj){return true;});