为什么会发生访问冲突


#include
#include

using namespace std;

class Carlo
{
private:
    double weight;
    double price;
    static double all_weight;
    static double all_price;
public:
    Carlo(double w, double p);
    ~Carlo();
    void printCarlo();
    static void printAllCarlo();
};
double Carlo::all_weight = 0;
double Carlo::all_price = 0;

Carlo::Carlo(double w, double p)
{
    weight = w;
    price = p;
    all_weight += weight;
    all_price += price;
}
Carlo::~Carlo()
{
    all_weight -= weight;
    all_price -= price;
}
void Carlo::printCarlo()
{
    cout << weight << "kg " << price << "yuan" << endl;
}
void Carlo::printAllCarlo()
{
    if(fabs(all_weight)<1e-8&& fabs(all_price) < 1e-8)
        cout << 0 << "kg " << 0 << "yuan" << endl;
    else
        cout << all_weight << "kg " << all_price << "yuan" << endl;
}

int main()
{
    Carlo* g1 = new Carlo[3]{ Carlo(3.2,5.8),Carlo(6.6,3.52),Carlo(7.1,3.79) };
    for (int i = 0; i < 3; i++)
    {
        g1[i].printCarlo();
    }
    Carlo::printAllCarlo();
    Carlo* g2 = new Carlo(9, 8);
    g2[0].printCarlo();
    Carlo::printAllCarlo();
    delete[]g1;
    Carlo::printAllCarlo();
    delete[]g2;
    Carlo::printAllCarlo();
}

img

测试过了,delete[]g2;错了,改为delete g2;,因为你是Carlo* g2 = new Carlo(9, 8);,new单个的

这个错误通常是由于访问了空指针或已经被释放的内存所导致的。可能是在程序中使用了已经被释放的内存或者指针未初始化就被使用了。建议检查代码中是否有这样的问题,并确保程序中所有使用的指针都已经正确初始化和释放。另外,也可以尝试使用调试工具来定位具体的错误位置和原因。

g2 是一个指向 Carlo 对象的指针,因此应该使用 new Carlo(9, 8) 来创建一个 Carlo 对象,而不是 new Carlo[1]{ Carlo(9, 8) }。因此,你可以将 g2 的创建语句修改为以下代码:
Carlo* g2 = new Carlo(9, 8);

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^