#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();
}
测试过了,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);