0xC0000005:访问冲突读取位置 0x00000000. 重载 == 运算符的问题
0xC0000005: Access violation reading location 0x00000000. issues with overloaded == operator
嗨,我目前正在为我正在学习的数据结构课程开发一个程序,我正在研究重载提取运算符的一部分。我当前收到错误访问冲突读取位置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;
}
相关文章:
- 一个关于在C++中重载布尔运算符的问题
- 使用运算符 [] 引用 std::vector 上最后一个元素时出现问题<>
- 运算符继承和 cpp 核心准则 c.128 的问题
- 在C++中使用重载提取运算符时出现问题
- 移动赋值运算符;尝试引用已删除的函数.我该如何解决这个问题?
- 关于条件块的问题与&&运算符有关
- 重载运算符与添加问题
- 加、乘、除、减复数的问题 C++ - 运算符重载
- C++中的三元条件运算符问题
- 重载+运算符问题与其他类中的友元函数混合
- C++中带有 cout 运算符问题的向量
- C++运算符=问题
- 模板类型的重载解析和运算符<<问题 - 第 2 部分
- 两相查找运算符<<问题?
- C++ 运算符问题 ()
- C++:如何将普通话(字符串)分配给用户使用数组输入的数字 &运算符问题
- 布尔运算符问题
- 相等运算符问题 (C++)
- 简单的运算符+问题躲避了我
- 重载运算符 I/O 问题