0xC0000005:访问冲突读取位置 0x00000000. 重载 == 运算符的问题

0xC0000005: Access violation reading location 0x00000000. issues with overloaded == operator

本文关键字:运算符 问题 重载 0x00000000 访问冲突 读取 位置 0xC0000005      更新时间:2023-10-16

嗨,我目前正在为我正在学习的数据结构课程开发一个程序,我正在研究重载提取运算符的一部分。我当前收到错误访问冲突读取位置0x00000000。当我尝试将两个 My String 对象相互比较时。MyString 对象本质上是一个 c String,这里是类定义

class MyString {
private:
char* str;
public:
MyString();
MyString(const char*);
MyString(const MyString&);
~MyString();
int length() const;
void read(istream&, char);
static const int MAX_INPUT_SIZE = 127;
MyString& operator=(const MyString&);
MyString& operator +=(const MyString&);
friend MyString operator +(const MyString&, const MyString&);

char operator[](int location)const;
char& operator[](int location);
friend ostream& operator<<(ostream&, const MyString&);
friend istream& operator>>(istream&, MyString&);
friend bool operator <(const MyString& left, const MyString& right);
friend bool operator <=(const MyString& left, const MyString& right);
friend bool operator >(const MyString& left, const MyString& right);
friend bool operator >=(const MyString& left, const MyString& right);
friend bool operator ==(const MyString& left, const MyString& right);
friend bool operator !=(const MyString& left, const MyString& right);
};
}
#endif

这是重载的 == 运算符抛出异常

bool operator ==(const MyString& left, const MyString& right) {
return strcmp(left.str, right.str) == 0;
}

这是我进行比较的上下文,假设 temp 是一个有效的 MyString 对象。

for (int i = 0; i < sizeof(cs_measure::Measure::unitStrings); i++) {
if (cs_measure::Measure::unitStrings[i] == temp) {
readMe.unit = i;
in >> readMe.unit;
}
}

这是在 for 循环中引用的数组

const MyString Measure::unitStrings[] =
{ "dram", "tsp", "tbsp", "oz", "cup", "pint",
"qt", "gal", "peck", "bushel", "barrel", "acre_ft" };

这是我第一次发布堆栈溢出,所以我遗漏了可能对解决此问题有用的任何关键信息,请告诉我,我很乐意提供帮助。

如注释中所述,sizeof(cs_measure::Measure::unitStrings)不是数组中的项目数cs_measure::Measure::unitStrings。它是数组在内存中占用的字节数。

由于以字节为单位的大小几乎肯定大于元素的数量,因此您将在循环中越界访问数组,从而导致未定义的行为。

您可以使用以下方法获取内置数组中的项目数

std::size(cs_measure::Measure::unitStrings)

自 C++17 起(如果未包含任何容器库标头,则可能需要#include<iterator>(。

或者,如果您不能使用 C++17,您可以定义自己的版本,尽管 C++17 标准版本功能更强大一些。(从 cppreference.com(:

template <class T, std::size_t N>
constexpr std::size_t size(const T (&array)[N]) noexcept
{
return N;
}