我想练习构建类。我在我的课上学到,内存泄漏从来都不是好事,当我调用这个类时,我是否正在创建一个对象,我是否需要在我的析构函数中添加一个delete函数来避免泄漏?谢谢!
#include <iostream>
#include <string>
using namespace std;
class Quadratic
{
public:
Quadratic(int ia, int ib, int ic);
int evaluate(int x);
private:
int a, b, c;
};
Quadratic::Quadratic(int ia, int ib, int ic)
{
a = ia;
b = ib;
c = ic;
}
int Quadratic::evaluate(int x)
{
int answer = a * (x * x) + b * x + c;
return answer;
}
Quadratic::~Quadratic() // ctrl + k + c to comment out large section of code.
{
cout << "Goodbye" << endl;
}
void main()
{
int list[3] = { 2,3,4 };
int* p1 = &list[0];
int* p2 = &list[1];
int* p3 = &list[2];
// calling a class looks like this
Quadratic* problem = new Quadratic(2, 3, 4);
int answer = problem->evaluate(0);
cout << answer << endl;
}发布于 2020-06-15 09:29:21
我可以看到你的代码有三个问题,首先是析构函数:在析构函数中,你应该释放在这种情况下创建的任何动态项,没有一个是好的,而且你应该将变量设置为它们的默认值。重置a、b和c的值。其次,调用问题->评估应该不起作用。我不会声明二次名称,只需声明二次名称。用problem.evalute替换problem->evalute。最后,除了模板之外,分离头文件和实现文件通常是行业惯例。
发布于 2020-06-15 09:31:04
C++不提供垃圾收集,所以您确实需要手动删除内存。
您可以通过键入以下命令来执行此操作
delete problem;
在您使用完它之后。
发布于 2020-06-15 09:32:42
您需要将析构函数添加到您的类函数中:
~Quadratic(); 此外,您还需要添加
delete problem;到你的主函数,重新释放你的指针占用的内存。
https://stackoverflow.com/questions/62379989
复制相似问题