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

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

概述我知道常见问题 How do I specify a pointer to an overloaded function?的答案:与作业或演员一样,每一个其他C教程都会加上一个这样的字符串(给或静态的): transform(in.begin(), in.end(), back_inserter(out), (int(*)(int)) std::toupper); 或者像这样: int (*fp) 我知道常见问题 How do I specify a pointer to an overloaded function?的答案:与作业或演员一样,每一个其他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!
总结

以上是内存溢出为你收集整理的c – 如何在算法中使用带有默认参数的重载函数?全部内容,希望文章能够帮你解决c – 如何在算法中使用带有默认参数的重载函数?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1243695.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存