这是我的功能
ostream margain(std::string firstWord)
{
ostream x;
x << std::setw(20) << firstWord;
return x;
}
在main中我想使用以下函数
std::cout<< margain("start") << "````````````````````````````````````" << std::endl;
// print things out
//then
std::cout<< margain("End") << "````````````````````````````````````" << std::endl;
我得到输出,开始或结束没有显示,返回值是
0````````````````````````````````````
我该如何解决?为什么?
修改 我知道该函数是导致这种情况的原因,因为如果我添加这个
cout&lt;&lt; std :: setw(20)&lt;&lt;第一个字; 在函数中,它打印正确,
我修复了它,不是最好的方法,而是
将该函数调用为
margain(std :: cout,“End”)&lt;&lt; “〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜=〜 “&lt;&lt; ENDL;
该功能看起来像
ostream& margain(ostream& stream, std::string firstWord)
{
stream << std::left << std::setw(10) << firstWord;
return stream;
}
谁知道更好的方法?
答案 0 :(得分:2)
您正在打印ostream的值,而不是firstword
的值。在这种情况下,ostream x
是未打开的流,因此它不会“执行”任何操作。由于编译器允许转换为bool
(C ++ 11)或void *
(在C ++ 11之前),因此将打印该转换的“值”。请注意,x
上的所有操作都不会影响cout
。
最简单的解决方案,我认为实际上是将std::setw(20)
添加到输出行:
std::cout<< std::setw(20 << "End" << "````````````````````````````````````" << std::endl;
另一种选择是将std::cout
传递给margain
,然后返回std::string
,如下所示:
std::string margain(ostream& x, const std::string& firstWord)
{
x << std::setw(20);
return firstWord;
}
然后你可以这样做:
std::cout<< margain(cout, "start") << "````````````````````````````````````" << std::endl;
但它并不完全灵活或“整洁”。
第三种选择当然是MarginString
类:
class MarignString
{
private:
int margin;
std::string str;
public:
MarginString(int margin, std::string str) margin(margin), str(str) {}
operator std::string() { return str; }
friend std::ostream& operator(std::ostream& os, const MarginString& ms);
};
std::ostream& operator(std::ostream& os, const MarginString& ms)
{
os << std::setw(ms.margin) << ms.str;
return os;
}
...
std::cout<< MarginString(20, "start") << "````````````````````````````````````" << std::endl;
请注意,最后一种方式可能不是那么好......;)
答案 1 :(得分:1)
struct margin
{
margin(std::string word) : word(word) { }
friend std::ostream& operator <<(std::ostream& os, margin const& m)
{
return os << std::setw(20) << m.word;
}
private:
std::string word;
};