C++模板不接受迭代器

1 c++ templates iterator quicksort

我正在重新学习C++,并开始尝试一个简单的算法:QuickSort.我的功能有这个签名:

template <class T>
void QSort(typename std::vector<T>::iterator begin, typename std::vector<T>::iterator end)
Run Code Online (Sandbox Code Playgroud)

它在我的主要功能中被调用:

int main()
{
    std::vector<int> unsort({56,32,11,45,67,81,12,5});
    std::vector<int>::iterator b=unsort.begin();
    std::vector<int>::iterator e=unsort.end();
    QSort(b, e);
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

并给出了这个错误:

C:\Users\Deus\Projects\QSort\main.cpp||In function 'int main()':|
C:\Users\Deus\Projects\QSort\main.cpp|49|error: no matching function for call to 'QSort(__gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int> > >&, __gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int> > >&)'|
||=== Build finished: 1 errors, 0 warnings ===|
Run Code Online (Sandbox Code Playgroud)

似乎编译器无法解析T应该是什么.有没有办法做我正在尝试做的事情,或者我应该将参数声明为类型T,并使用由此产生的不确定性?

Joh*_*itb 5

编译器无法T从函数调用中推断出来.想想会发生什么情况std::vector<T>::iteratorT*:

int *b = ...;
int *e = ...;
QSort(b, e);
Run Code Online (Sandbox Code Playgroud)

一般来说,如果你写typename Something<TemplateParameter>::anotherThing,那么TemplateParemter就不能在通话中推断出来.必须明确提供

QSort<int>(b, e);
Run Code Online (Sandbox Code Playgroud)

我建议只使用T参数类型.这将让你不仅接受矢量迭代器,而且T*,或者std::deque<T>::iterator和任何其他随机访问迭代器.