我的问题是我尝试调用我的模板函数测试,它需要指向另一个模板函数的指针。因为你不能有指向函数的模板化指针,所以我通过在 struct 中包装这样的 typedef 指针来做到这一点(请参阅Template typedefs - What's your work around?)。没关系 - 我可以通过指针调用我的模板函数,但问题是我不能调用以这个指针作为参数的函数。VS2010中的错误是:
c:\projects\sort\sort\sort.cpp(114): 错误 C2059: 语法错误: '}' c:\projects\sort\sort\sort.cpp(124) : 请参阅函数模板实例化 'void test (void (__cdecl *)(std::vector<_Ty> &))' 使用 [ _Ty=int ] 编译
构建失败。
_Ty 是 int,没关系,对吧?
#include "stdafx.h"
#include <vector>
#include <iterator>//for ostream_iterator
#include <algorithm>//for copy
#include <iostream>//for cout
#include <map>
#include <boost/timer/timer.hpp>
#include <boost/random.hpp>
#include <functional>
template <typename T>
void insert_sort(typename std::vector<T>& v){ // O(n^2)
for(std::vector<T>::iterator it=v.begin();it!=v.end();it++){
std::vector<T>::iterator it2=it; // [0,...,i-1] has been sorted already
T temp = *it2;
while(it2!=v.begin() && *(it2-1)>temp){
*(it2)=*(it2-1);
it2--;
}
*(it2)=temp;
}
}
void f(int i){std::cout<<i<<" ";}
template<typename T>
struct sort_struct{
typedef void (*func_sort)(std::vector<T>& );
typedef std::map<int,T> mymap;
};
template<typename T>
double sortTime(std::vector<T>& v, typename sort_struct<T>::func_sort f){
boost::timer t; // start timing
f(v);
return t.elapsed();
}
template<typename T>
void test(typename sort_struct<T>::func_sort f){
int i=100;
while(i<0xFF){
boost::mt19937 marsenneTwister;
boost::uniform_int<> unigen;
boost::variate_generator<boost::mt19937, boost::uniform_int<> >
gen(marsenneTwister, unigen);
std::vector<int> randVec(i);
std::random_shuffle(randVec.begin(), randVec.end(), gen);
double elapsed = sortTime(randVec,f);
std::cout<<i<<","<<elapsed<<std::endl;
i+=100;
}
}
int _tmain(int argc, _TCHAR* argv[])
{
std::vector<int> vi(2);
sort_struct<int>::func_sort isort_int=insert_sort<int>;
(*isort_int)(vi); // this is OK
// how to instantiate and call test<int> ?
test<int>(isort_int); // error
//...
}