- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个程序使用一个类来动态分配一个数组。我有重载运算符,可以对来自该类的对象执行操作。
当我测试这个程序时,重载的 += 工作,但 -= 不工作。 当试图运行重载的 -= 时程序崩溃,我得到以下运行时错误: p>
malloc: * error for object 0x7fd388500000: pointer being freed was not >allocated * set a breakpoint in malloc_error_break to debug
在私有(private)成员变量中,我这样声明数组:
double* array_d;
然后我在重载的构造函数中动态分配数组:
Students::Students(int classLists)
{
classL = classLists;
array_d = new double[classL];
}
我将以下两个重载构造函数定义为 Students 类的友元:
friend Student operator+= (const Student&, const Student&);
friend Student operator-= (const Student&, const Student&);
这些是这样定义的:
Student operator+= (const Student& stu1, const Student& stu2)
{
if (stu1.getClassL() >= stu2.getClassL())
{
for (int count = 0; count < stu.getClassL(); count++)
stu1.array_d[count] += stu2.array_d[count];
return (stu1);
}
else if (stu1.getClassL() < stu2.getClassL())
{
for (int count = 0; count < stu1.getClassL(); count++)
stu1.array_d[count] += stu2.array_d[count];
return (stu1);
}
}
Student operator-= (const Student& stu1, const Student& stu2)
{
if (stu1.getClassL() >= stu2.getClassL())
{
for (int count = 0; count < stu2.getClassL(); count++)
stu1.array_d[count] -= stu2.array_d[count];
return (stu1);
}
else if (stu1.getClassL() < stu2.getClassL())
{
for (int count = 0; count < stu1.getClassL(); count++)
stu1.array_d[count] -= stu2.array_d[count];
return (stu1);
}
}
基本上这里发生的事情是我比较两个对象,数组的大小基于 classL 而不同。 getClassL()
函数很简单:int Student::getClassL() const {return classLists;}
如果您想知道,我已经以这种方式让三巨头重载了:
<强>1。析构函数: Student::~Student() {delete [] array_d;}
<强>2。复制构造函数:
Student::Student(const Student &student)
{
classLists = student.classLists;
array_d = student.array_d;
}
<强>3。赋值运算符:
Student &Student::operator=(const Student &student)
{
classLists = student.classLists;
array_d = student.array_d;
}
奇怪的是 += 有效但 -= 无效,因为它们实际上是相同的。我怀疑我的问题出在我的动态内存分配上,但我不确定并正在寻求专家建议。
最佳答案
给你的建议是使用 std::vector
并且让你自己不必实现赋值运算符、复制构造函数和析构函数。
但话说回来,代码中有一些错误,更不用说复制构造函数了。
首先,复制构造函数应该分配一个全新的数组,并将传入值中的值从数组复制到新数组。这是您的 Student
类的简化版本,只有两个成员——一个 double *
和一个表示数组中项目数的整数。
class Student
{
int num;
double *array_d;
public:
Student(const Student &student);
Student& operator=(const Student &student);
~Student() { delete [] array_d; }
Student() : array_d(0), num(0) {}
};
复制构造函数看起来像这样:
Student::Student(const Student &student) :
array_d(new double[student.num]), num(student.num)
{
for (int i = 0; i < num; ++i )
array_d[i] = student.array_d[i];
}
一旦有了这个,赋值运算符就很简单了,使用 copy / swap:
Student& Student::operator=(const Student &student)
{
Student temp = student;
std::swap(d_array, temp.d_array);
std::swap(num, temp.num);
return *this;
}
基本上,上面所做的就是制作传入对象的临时拷贝,将临时对象的内部结构与当前对象交换,然后临时对象与旧内部结构一起消失。除非 Student
的复制构造函数和析构函数正常工作(它们现在应该正常工作),否则所有这一切都是不可能的。
接下来要考虑的是您对运算符 +=
和 -=
的整体想法。大多数程序员期望使用它的方式是在这种情况下:
Student a;
Student b;
// assume a and b are initialized and have data...
a += b;
如果您以不同的形式使用 +=
或 -=
,它会变得不直观而且很奇怪。因此,这些函数应该采用单个参数,而不是两个参数,并返回当前对象(它是您正在更改的当前对象)。
因此这些函数不应该是友元函数,而是Student
的类成员函数:
class Student
{
int num;
double *array_d;
public:
Student(const Student &student);
Student& operator=(const Student &student);
~Student() { delete [] array_d; }
Student() : array_d(0), num(0) {}
Student& operator += (const Student& rhs);
Student& operator -= (const Student& rhs);
};
那么 +=
的实现看起来像这样:
#include <algorithm>
//...
Student& operator+= (const Student& stu1)
{
int num_to_add = std::min(num, stu1.num);
for (int count = 0; count < num_to_add; ++count)
array_d[count] += stu1.array_d[count];
return *this;
}
类似地,-=
看起来像上面那样。请注意使用 std::min
来确定要添加的数量,而不是使用 if/else
的原始代码。
关于C++:使用重载的复合赋值运算符时出现运行时错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32706584/
Or 运算符 对两个表达式进行逻辑“或”运算。 result = expression1 Or expression2 参数 result 任意数值变量。 expression1 任意
Not 运算符 对表达式执行逻辑非运算。 result = Not expression 参数 result 任意数值变量。 expression 任意表达式。 说明 下表显示如何
Is 运算符 比较两个对象引用变量。 result = object1 Is object2 参数 result 任意数值变量。 object1 任意对象名。 object2 任意
\ 运算符 两个数相除并返回以整数形式表示的结果。 result = number1\number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
And 运算符 对两个表达式进行逻辑“与”运算。 result = expression1 And expression2 参数 result 任意数值变量。 expression1
运算符(+) 计算两个数之和。 result = expression1 + expression2 参数 result 任意数值变量。 expression1 任意表达式。 exp
我对此感到困惑snippet : var n1 = 5-"4"; var n2 = 5+"4"; alert(n1); alert(n2); 我知道 n1 是 1。那是因为减号运算符会将字符串“4”转
我想我会得到 12,而不是 7。 w++,那么w就是4,也就是100,而w++, w 将是 8,1000;所以 w++|z++ 将是 100|1000 = 1100 将是 12。 我怎么了? int
Xor 运算符 对两个表达式进行逻辑“异或”运算。 result = expression1 Xor expression2 参数 result 任意数值变量。 expression1
Mod 运算符 两个数值相除并返回其余数。 result = number1 Mod number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
Imp 运算符 对两个表达式进行逻辑蕴涵运算。 result = expression1 Imp expression2 参数 result 任意数值变量。 expression1 任
Eqv 运算符 执行两个表达式的逻辑等价运算。 result = expression1 Eqv expression2 参数 result 任意数值变量。 expression1 任
我有一个运算符重载的简单数学 vector 类。我想为我的运算符(operator)获取一些计时结果。我可以通过计时以下代码轻松计时我的 +=、-=、*= 和/=: Vector sum; for(s
我是用户定义比较运算符的新手。我正在读一本书,其中提到了以下示例: struct P { int x, y; bool operator、运算符<等),我们
在 SQL 的维基百科页面上,有一些关于 SQL 中 bool 逻辑的真值表。 [1] 维基百科页面似乎来源于 SQL:2003 标准。 等号运算符 (=) 的真值表与 SQL:2003 草案中的 I
我遇到了一个奇怪的 C++ 运算符。 http://www.terralib.org/html/v410/classoracle_1_1occi_1_1_number.html#a0f2780081f
我正在阅读关于 SO 和 answers 中的一个问题,它被提到为: If no unambiguous matching deallocation function can be found, pr
我偶然发现了这个解决方案,但我无法理解其中到底发生了什么。谁能解释一下! 据我了解,它试图通过计算一半的单元格然后将其加倍来计算 a*b 网格中的单元格数量。但是我无法理解递归调用。 请不要建议其他解
Go的基本类型 布尔类型bool 长度:1字节 取值:布尔类型的取值只能是true或者false,不能用数字来表示 整型 通用整型 int / uint(有符号 / 无符号,下面也类似) 长度:根据运
在本教程中,您将学习JavaScript中可用的不同运算符,以及在示例的帮助下如何使用它们。 什么是运算符? 在JavaScript中,运算符是一种特殊符号,用于对运算数(值和变量)执行操作。例如,
我是一名优秀的程序员,十分优秀!