加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 04:59:21 所属栏目:百科 来源:网络整理
导读:我知道常见问题 How do I specify a pointer to an overloaded function?的答案:与作业或演员一样,每一个其他C教程都会加上一个这样的字符串(给或静态的): transform(in.begin(),in.end(),back_inserter(out),(int(*)(int)) std::toupper); 或者像这样: i
我知道常见问题 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!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读