我想打印一对,例如
std::cout << make_pair(std::string,int) << endl;
但它没有编译,因为operator<<(ostream &, std::pair<std::string,int>)
未定义。
但是因为我们现在有了带有lambda函数的c ++ 11,所以我可以使用带有for_each
表达式的lambda函数来处理容器。
对于上述情况,我如何提供ostream可用于打印该对的“就地方法”?
答案 0 :(得分:1)
Pairs(和其他元组)并不像容器,因为它们的元素具有异构类型。它们不能以正常方式迭代。所以lambda在这里并不适用。
如果需要,只需定义一个output_pair
模板函数,它接受一个ostream和一对,并输出该对的两个元素。或者如果你想保留提取样式,你可以让output_pair
返回一个output_pair_struct
除了保存元组的副本之外什么都不做,并定义一个运算符&lt;&lt;在完成实际工作的output_pair_struct
上,您可以std::cout << output_pair(mypair) << endl;
。
答案 1 :(得分:0)
对于上述情况,我如何提供&#34;就地方法&#34; ostream可以用来打印这对吗?
auto print = [&](const std::pair<std::string,int>& p) {
std::cout << p.first << ", " << p.second << "\n";
};
std::map<std::string,int> sequence = { /* ... */ };
for_each(sequence.begin(), sequence.end(), print);
for(const auto& p: sequence)
print(p);
或:
for_each(sequence.begin(), sequence.end(),
[&](const std::pair<std::string,int>& p) {
std::cout << p.first << ", " << p.second << "\n";
});
无论哪种方式,这都太复杂了。你应该这样写:
for(const auto& p: sequence)
std::cout << p.first << ", " << p.second << "\n";