C++Primer Plus(第六版) 第十二章 第一题

本题主要是对本章基本内容的掌握,对于动态分配内存(new、new[])的情况下析构函数要对应用delete、delete[],同时由于析构函数只有一个,故注意所有的构造函数(包括重载的=运算符等)都采用相同的动态内存分配方式。

代码如下:

#include <iostream>
#include "cow.h"

Cow::Cow()
{
	hobby = new char[1];
	hobby[0] = '\0';
}

Cow::Cow(const char * nm, const char * ho, double wt)
{
	strcpy(name, nm);
	hobby = new char[strlen(ho) + 1];
	strcpy(hobby, ho);
	weight = wt;
}

Cow::Cow(const Cow & c)
{
	strcpy(name, c.name);
	hobby = new char[strlen(c.hobby) + 1];
	strcpy(hobby, c.hobby);
	weight = c.weight;
}

Cow::~Cow()
{
	delete[] hobby;
}

Cow & Cow::operator=(const Cow & c)
{
	if (this == &c)
		return *this;
	strcpy(name, c.name);
	delete[] hobby;
	hobby = new char[strlen(c.hobby) + 1];
	strcpy(hobby, c.hobby);
	weight = c.weight;
	return *this;
}

void Cow::showCow() const
{
	using std::cout;
	using std::endl;
	cout << "name: " << name << endl;
	cout << "hobby: " << hobby << endl;
	cout << "weight: " << weight << endl;
}
测试代码:

#include <iostream>
#include "cow.h"
using namespace std;
int main()
{
	{
		Cow cow();
	}
	Cow cow("abcd", "habby", 45);
	Cow adc = cow;
	cow.showCow();
	adc.showCow();
	cin.get();
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值