Ich versuche, einen Iterator als Template-Parameter in einer Vorlage Methode zu übergeben, aber der Compiler beschwert sich, dass ableiten:Kann nicht Vorlagentyp
error C2783: 'void Test::Assert(std::vector<T>::const_iterator)':
could not deduce template argument for 'T'
Der Code, der den Fehler erzeugt ist:
#include "stdafx.h"
#include <iostream>
#include <vector>
class Test
{
public:
template <typename T>
void Assert(typename std::vector<T>::const_iterator it)
{
std::cout << *it << std::endl;
}
};
int _tmain(int argc, _TCHAR* argv[])
{
Test test;
std::vector<double> myVec;
test.Assert(myVec.cbegin());
return 0;
}
Ich denke, es gibt eine einfache Möglichkeit, dies zu tun, da die meisten der Std-Algorithmen Typ aus Iterator abzuleiten.
möglich Duplikat [Behelfslösung für nicht-abgeleitete Kontext] (http://stackoverflow.com/questions/8308213/workaround-for-non-deduced-context) – vsoftco