【问题标题】:setw within a function to return an ostreamsetw 在函数中返回一个 ostream
【发布时间】:2013-09-05 14:08:17
【问题描述】:

这是我的功能

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

我修复了它,不是最好的方法,而是作为

调用函数为

保证金(std::cout,“结束”)

函数看起来像

ostream& margain(ostream& stream, std::string firstWord)
{
    stream << std::left << std::setw(10) << firstWord;
    return stream;
}

有人知道更好的方法吗?

【问题讨论】:

  • 当您在margain中声明x时,这样做是否会发生编译器错误?当我这样做时,我被告知“std::basic_ostream<_elem>”出现错误,因为没有合适的默认构造函数可用。

标签: c++ cout ostream setw


【解决方案1】:

您正在打印 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;

请注意,最后一种方式可能也不是那么好... ;)

【讨论】:

    【解决方案2】:
    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;
    };
    

    【讨论】:

    • 我认为operator&lt;&lt;函数需要在struct之外(或者是一个非朋友但静态的函数)
    • 它可以很好地编译,但是operator &lt;&lt; 的第一个参数应该是ostream,在你的情况下,它应该是this,对吧?还是在函数前面贴friend 和static 有类似的效果,不再是成员函数?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-04-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多