1

我正在做一个小程序来模拟使用基本字符串。它目前无法始终如一地工作。

在这种情况下,程序工作正常:

a = a+ w + 10 + " " + L"x" + 65.5 ; 

但是,如果我以这种方式写相同的句子,所有工作都不好:

a = + w + 10 + " " + L"x" + 65.5 ; 

谁能向我解释我的程序有什么问题?

class sstring {
public:
    string s;

    sstring() {s.assign("");}

    template <class T>
    sstring& operator=(T i) {
        s = to_string( i );
        return *this;
    }

    sstring& operator=(const char *i) {
        s = i;
        return *this;
    }

    sstring& operator=(const wchar_t *w) {
        wstring ws = w;
        s.assign ( ws.begin(),ws.end() );
        return *this;
    }

    sstring& operator=(wstring w) {
        s.assign ( w.begin(),w.end() );
        return *this;
    }
    // *********************************************** +
    template <class T>
    sstring& operator+(T i) {
        s.append( to_string( i ));
        return *this;
    }

    sstring& operator+(const char *i) {
        s.append(i);
        return *this;
    }

    sstring& operator+(const wchar_t *i) {
        wstring ws = i;
        ws.assign(i);
        string cs;
        cs.assign ( ws.begin(),ws.end() );
        s.append( cs );
        return *this;
    }

    sstring& operator+(wstring w) {
        string temp;

        temp.assign( w.begin(),w.end() );
        s.append ( temp );
        return *this;
    }
    //*************************************************** <<
    friend ostream& operator<<( ostream &out,sstring obj);

};

ostream& operator<<( ostream &out,sstring obj) {
    out << obj.s;
    return out;
}

int main(void) {
    sstring a;
    wstring w;

    w = L"claudio";
    a = "daffra";
    a = a + w + 10 + " " + L"x" + 65.5;

    cout << "\ns :" << a;

    return 1;
}
4

2 回答 2

1

a = w + 10 + " " + L"x" + 65.5不起作用,因为w它不是类型,所以不使用sstring你的重载。operator+尝试例如在前面添加一个空sstring: a = sstring() + w + 10 + " " + L"x" + 65.5;

于 2013-02-25T14:39:30.317 回答
0

这两行将给出相同的结果:

int x;

x = x + 4;
x += 4;

您建议的替代行是以下形式:

x =+ 4;

PARSED与以下内容相同:

x = +4;

我们看到的是(尽管这可以为类重载):

x = 4;

如果它们实现了大多数人期望的正常行为,这也将适用于您的 wstring 和 sstring 类。从粗略的扫描来看,您似乎正试图保持这种行为。

附加说明:让我们看一下两个解析树。

a = a + 9 + " ";

这将做:

operator+(typeof(a), int);
operator+(typeof_previous_line, const char *);

您可能已经重载了类型 + 一个 int 和 + 一个 const char* 才能工作。

另一方面:

a += 9 + " ";

那会做:

operator+(int, const char *);
operator+=(typeof_previous_line);

您可能没有定义这两个操作中的第一个。一个常见的解决方法是将第一项转换为您的结果类型。所以像:

a += sstring(9) + " ";    // or
a += sstring() + 9 + " ";
于 2013-02-25T14:33:58.053 回答