gpt4 book ai didi

c++ - 派生类使用基类中的重载运算符时出错

转载 作者:太空宇宙 更新时间:2023-11-04 12:20:11 24 4
gpt4 key购买 nike

我会发布我的问题,然后我会将代码放在底部。

我有一个重载 +,-,*,= 运算符的基类 (strSet)。
我有一个重载了 <,>,== 运算符的派生类 (extStrSet)

在派生类中重载“<”和“>”运算符的实现中,我必须使用“*”运算符(来自基类)。

但我收到一个错误,我真的不确定为什么会这样。错误是这样说的:

extstrset3.cpp: In member function âextStrSet extStrSet::operator>(const extStrSet&)â:  

extstrset3.cpp:17: error: no match for âoperator=â in âtemp = strSet::operator*(const strSet&)(((const strSet&)(&((const extStrSet*)rtSide)->extStrSet::<anonymous>)))â

extstrset3.h:11: note: candidates are: extStrSet& extStrSet::operator=(const extStrSet&)
extstrset3.cpp: In member function âextStrSet extStrSet::operator<(const extStrSet&)â:

extstrset3.cpp:29: error: no match for âoperator=â in âtemp = strSet::operator*(const strSet&)(((const strSet&)(&((const extStrSet*)rtSide)->extStrSet::<anonymous>)))â

extstrset3.h:11: note: candidates are: extStrSet& extStrSet::operator=(const extStrSet&)

extstrset3.cpp:35: error: ânewSetâ was not declared in this scope

extstrset3.cpp: In member function âextStrSet extStrSet::operator==(const extStrSet&)â:

extstrset3.cpp:41: error: no match for âoperator=â in âtemp = strSet::operator*(const strSet&)(((const strSet&)(&((const extStrSet*)rtSide)->extStrSet::<anonymous>)))â

extstrset3.h:11: note: candidates are: extStrSet& extStrSet::operator=(const extStrSet&)

extstrset3.cpp:45: error: ânewSetâ was not declared in this scope

注意:我不会更改这两个头文件中的任何一个。
注意:我知道 strSet.h 和 strSet.cpp 的实现是正确的。
注意:重载的 '==' 运算符返回一个以“true”或“false”作为唯一字符串的 extStrSet(字符串集)

我应该能够在 extStrSet 上使用 * 运算符,即使它对于 strSet 来说是重载的,不是吗?我才刚刚开始继承,所以我还是有点担心。

strSet.h

#ifndef STRSET_H
#define STRSET_H

#include <iostream>
#include <vector>
#include <string>

struct node {
std::string s1;
node * next;
};

class strSet {

protected:
node * first;
// This is initially empty (when constructed)
bool isSorted () const;

public:
strSet (); // Create empty set
strSet (std::string s); // Create singleton set
strSet (const strSet &copy); // Copy constructor
~strSet (); // Destructor

void nullify (); // Make a set be empty
bool isNull () const;
int SIZE() const;

void output() const;

bool isMember (std::string s) const;

strSet operator + (const strSet& rtSide); // Union
strSet operator * (const strSet& rtSide); // Intersection
strSet operator - (const strSet& rtSide); // Set subtraction
strSet& operator = (const strSet& rtSide); // Assignment


}; // End of strSet class

#endif

extStrSet.h

#ifndef EXTSTRSET_H
#define EXTSTRSET_H

#include <string>
#include "strset3.h"

class extStrSet : public strSet
{
public:
extStrSet operator == (const extStrSet& rtSide); // Equal
extStrSet operator < (const extStrSet& rtSide); // Strict subset
extStrSet operator > (const extStrSet& rtSide); // Strict superset
// Leave off other comparisons: != <= >=

extStrSet ( );
extStrSet (std::string s);
};

inline extStrSet& ss2extss (const strSet& ss) // Downcast
{ return *(extStrSet*)&ss ; }

#endif

extStrSet.cpp

#include <iostream>
#include <vector>
#include <string>
#include "extstrset3.h"
#include "strset3.h"

using namespace std;

extStrSet::extStrSet() : strSet() {}

extStrSet::extStrSet(string s) : strSet(s) {}

extStrSet extStrSet::operator > (const extStrSet& rtSide) {
extStrSet temp;
extStrSet temp2;
extStrSet newSet;
temp = *this * rtSide;
temp2 = *this == rtSide;
if(temp2.isMember("true")) extStrSet newSet("false");
else if( rtSide.SIZE() == temp.SIZE() ) extStrSet newSet("true");
else extStrSet newSet("false");
return newSet;
}

extStrSet extStrSet::operator < (const extStrSet& rtSide) {
extStrSet temp;
extStrSet temp2;
temp = *this * rtSide;
temp2 = *this == rtSide;
if(temp2.isMember("true")) extStrSet newSet("false");
else if( SIZE() == temp.SIZE() ) extStrSet newSet("true");
else extStrSet newSet("false");
return newSet;

}

extStrSet extStrSet::operator == (const extStrSet& rtSide) {
extStrSet temp;
temp = *this * rtSide;
if( SIZE() == rtSide.SIZE() && SIZE() == temp.SIZE() ) extStrSet newSet("true");
else extStrSet newSet("false");
return newSet;
}

最佳答案

这是因为 strSet::operator*() 返回的是 strSet 而不是 extStrSet。要清楚这个表达式

*this * rtSide; 

返回一个strSet。这部分

extStrSet temp =

期望被赋予一个extStrSet,但它被赋予了一个strSet。你有这个功能

inline extStrSet& ss2extss (const strSet& ss)  // Downcast
{ return *(extStrSet*)&ss ; }

用于从 strSet 转换为 extStrSet。我相信在这种情况下你可以做到

temp = ss2extss(*this * rtSide);

但需要注意的是,这只是有效的,因为这些类中没有虚函数,extStrSet 也没有添加任何数据成员。困难在于 * 运算符被定义为

strSet operator*(strSet &rhs)

这是按值返回而不是按引用返回。这意味着即使该函数有一个返回 extStrSet 的 return 语句,它的 extStrSet 部分也会被截断。在这种情况下,由于缺少虚函数和数据成员,我相信这几乎适用于任何编译器,但即便如此,我也不能 100% 确信这不依赖于未定义的行为。

关于c++ - 派生类使用基类中的重载运算符时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5508996/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com