|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
代码:
#include <iostream>
#include <cstring>
using namespace std;
template <class T>
void sort(T arr[], int size, bool (*f)(T,T)){
bool flag;
for(int i=1;i<size;i++){
flag=false;
for(int j=0;j<size-i;j++)
{
if(!f(arr[j],arr[j+1])){
T temp;
temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
flag=true;
}
}
if(!flag) break;
}
}
int main()
{
int a[]={2,5,9,4,7,3,6,1,0,8};
char *b[]={"aaa","bbb","ccc","ddd"};
sort(a,10, [](int x,int y)->bool {return x>y;});
for(int i:a) cout<<i<<" ";
cout<<endl;
sort(a,10,[](int x,int y)->bool {return x<y;});
for(int i:a) cout<<i<<" ";
cout<<endl;
sort(b,4,[](char *x,char *y)->bool{return strcmp(x,y)<0;});
for(int i=0;i<4;i++) cout<<b[i]<<" ";
cout<<endl;
sort(b,4,[](char *x,char *y)->bool{return strcmp(x,y)>0;});
for(int i=0;i<4;i++) cout<<b[i]<<" ";
cout<<endl;
return 0;
}
以上代码为一个冒泡排序的通用模板,当我用lambda表达式作为sort的实参时会报错,形参和实参不匹配,想问下形参应该怎样写??谢谢!
祝大家节日快乐~
本帖最后由 Croper 于 2019-10-24 21:17 编辑
嗯。。最主要的原因是因为lambda表达式和函数指针是两个不同的类型;
在平常的使用中,经常吧lambda和函数指针混用是因为其中有一个隐式类型转换;
但是一旦套用到模板中, 模板的参数通常不会进行类型转换(才能生成对应类型的函数)。换句话说,在其中不会进行lambda到函数指针的默认类型转换,而是直接报类型不匹配的错误。
参考algorithm中自带的sort函数 template<class _RanIt,
[code]
template<class _RanIt,
class _Pr> inline
void sort(const _RanIt _First, const _RanIt _Last, _Pr _Pred)
{ // order [_First, _Last), using _Pred
_Adl_verify_range(_First, _Last);
const auto _UFirst = _Get_unwrapped(_First);
const auto _ULast = _Get_unwrapped(_Last);
_Sort_unchecked(_UFirst, _ULast, _ULast - _UFirst, _Pass_fn(_Pred));
}
可以看到,标准库中的sort函数直接将你放置函数指针的形参的位置模板化了,同样,你也可以这样修改 template <class T,class T2>
void sort(T arr[], int size, T2 f)
或者另一个方法,是在主函数中将lambda表达式强制转换为函数指针 sort(a,10,(bool (*)(int,int))([](int x,int y)->bool {return x>y;}));
|
|