c – 如何在算法中使用带有默认参数的重载函数?

前端之家收集整理的这篇文章主要介绍了c – 如何在算法中使用带有默认参数的重载函数?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我知道常见问题 @L_502_0@的答案:与作业或演员一样,每一个其他C教程都会加上一个这样的字符串(给或静态的):
transform(in.begin(),in.end(),back_inserter(out),(int(*)(int)) std::toupper);

或者像这样:

int (*fp)(int) = std::toupper;
transform(in.begin(),fp);

它整齐地选择< cctype> std :: toupper的重载.

但是这就提出了一个问题:如何选择< locale>过载以类似的方式?

char (*fp2)(char,const std::locale&) = std::toupper;
transform(in.begin(),fp2);
// error: too few arguments to function

或者更实际的是,考虑有人试图在一个算法中使用C 11 std :: stoi将一个字符串向量转换为整数向量:stoi有两个重载(string / wstring),每个都有两个额外的默认参数.

假设我不想要explicitly bind所有这些默认值,我相信这是不可能的,而不需要在辅助函数或lambda中包装这样的调用.有没有提升包装或TMP魔法为我完全通用的方式?甚至可以写一个包装器,如call_as< char(char)>(fp2)或更有可能的是call_as< int(const std :: string&)>(std :: stoi)

解决方法

很有趣,我在做类似的事情.我发现做的最好的方法是使用lambdas如下,因为否则,你必须使用一个typedef来获得正确的重载和一个std :: bind来摆脱语言环境,或不使用语言环境.但是,这样做比较干净:
static const std::locale loc;
transform(in.begin(),[&loc](char c) {
  return std::toupper(c,loc);
});

我使用静态来节省每次重新分配的努力.

或者你可以得到一个typedef并做:

std::bind((LocaleCompare)std::toupper,std::placeholders::_1,loc); // UGLY!
原文链接:https://www.f2er.com/c/115086.html

猜你在找的C&C++相关文章