我有以下代码。我试图消除将localization_data_t::language_t
类型显式传递给lambda参数的需要。
auto language_itr = std::find_if(languages.begin(), languages.end(), [&](const localization_data_t::language_t& language)
{
return language.code == language_code;
});
我假设有一种方法可以做到这一点,因为要迭代的对象的类型可以由编译器通过迭代器的底层类型派生。但是,我在旅行中没有找到这样的例子。
任何帮助都将不胜感激。
答案 0 :(得分:7)
您可以在C ++ 11中使用decltype
:
auto result = std::find_if(v.begin(), v.end(), [](const decltype(*v.begin())& t) { /* */ });
在C ++中你可以使用auto
。
auto result = std::find_if(v.begin(), v.end(), [](const auto& t) { /* */ });
还有std::iterator_traits
,但它更详细。