Рассмотрим следующий код:
#include <vector>
struct S { int a; double b; };
int main()
{
std::vector<S> v;
v.push_back({3, 4.5});
}
g ++ 4.4 жалуется, что вызов push_back () неоднозначен:
error: call of overloaded ‘push_back(<brace-enclosed initializer list>)’ is ambiguous
note: candidates are: void std::vector<_Tp, _Alloc>::push_back(const _Tp&) [with _Tp = S, _Alloc = std::allocator<S>]
note: void std::vector<_Tp, _Alloc>::push_back(_Tp&&) [with _Tp = S, _Alloc = std::allocator<S>]
Это должно быть неоднозначным в соответствии со Стандартом, или это просто проблема с g ++?
Я знаю, что это можно решить, написав явно тип S:
v.push_back(S{3, 4.5});
но имя типа S может быть длинным, поэтому я бы не стал этого делать ...