Nicht statische Initialisierung von Datenelementen mit neuem Ausdruck
Betrachten Sie den folgenden Code:
#include <map>
template <typename T>
struct X {
std::map<int, T>* storage = new std::map<int, T>();
};
int main() {
X<int> x;
}
Dies kompiliert aufclang 3.6.0, kann aber am @ nicht kompiliergcc 5.1. Es würde jedoch kompilieren, wenn der Typ vonstorage
waren stattdessenstd::vector<T>*
(oder nurT*
).
Ich bin mir ziemlich sicher, dass dies ein Compiler-Fehler von gcc is 66344), aber dachte, ich würde fragen, um sicherzustellen: Gibt es einen Grund, das obige Beispiel sollte nicht compile?
gcc Kompilierungsfehler:
main.cpp:5:51: error: expected ';' at end of member declaration
std::map<int, T>* storage = new std::map<int, T>();
^
main.cpp:5:51: error: declaration of 'std::map<int, T> X<T>::T'
main.cpp:3:11: error: shadows template parm 'class T'
template <typename T>
^
main.cpp:5:52: error: expected unqualified-id before '>' token
std::map<int, T>* storage = new std::map<int, T>();
^
main.cpp:5:46: error: wrong number of template arguments (1, should be at least 2)
std::map<int, T>* storage = new std::map<int, T>();
^
In file included from /usr/local/include/c++/5.1.0/map:61:0,
from main.cpp:1:
/usr/local/include/c++/5.1.0/bits/stl_map.h:96:11: note: provided for 'template<class _Key, class _Tp, class _Compare, class _Alloc> class std::map'
class map
^