Aktywne Wpisy

RobieZdrowaZupke +18
Tam już się nie da wrócić
źródło: 201115173830812848
Pobierz
n0spRezydenta +26
#sebcel Jeremy Renner dołącza do sebcelwersum, piszcie kogo brakuje
źródło: 1000003515
PobierzSkopiuj link
Skopiuj link
źródło: 201115173830812848
Pobierz
źródło: 1000003515
PobierzRegulamin
Reklama
Kontakt
O nas
FAQ
Osiągnięcia
Ranking
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 dereferencjaUbę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){returnboost::find_if(tab | boost::adaptors::indirected, [](const Object& obj){return true;});