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 – 如何在算法中使用带有默认参数的重载函数?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)