【C++札记】构造函数与析构函数

构造函数(constructor)

1.构造函数是种特殊的类成员函数,遵循如下规则:

     a.函数名与类名必须相同。

     b.没有返回值

例如:
class Obj
{
...
public:
      Obj()
      {
         ...
      }
};


2.构造函数可以带参数,也可以重载

 

 

class Obj
{
...
public:
      Obj()
      {
        ...
      }
      Obj(int x, int y)
      {
        ...
      }
};

3.构造函数和普通成员函数不一样,一般不显示调用。在创建一个对象时,构造函数自动调用(编译器来完成)。

 

析构函数(destructor)

1.析构和构造是一对相反的过程,对象被创建时调用构造函数,对象被销毁时调用析构函数,遵循如下规则:

    a.名称固定,类名前加上波浪线~

    b.没有返回值

    c.不能带参数

例如,
class Obj
{
public:
    ~Obj()
     {
     }
};


2.析构函数只能有一个,不允许重载。

 

3.析构函数不显示调用,对象销毁时编译器自动调用。

重新实现链表(使用类,构造和析构函数)

创建DataObj.h头文件

#ifndef _OBJECT_H_
#define _OBJECT_H_

struct Student
{
	char name[32];
	int  age;
	Student* pNext;
};

class DataObj
{
public:
	DataObj();
	~DataObj();
	void add(Student* pStu);
	void find(int age);
	void printNode(Student* pNode);
private:
	Student m_head;
};

#endif


创建DataObj.cpp源文件

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "DataObj.h"

//构造有头链表
DataObj::DataObj()
{
	m_head.pNext = NULL;
}
DataObj::~DataObj()
{
	//指向每个节点的头部
	Student* p = m_head.pNext;

	//释放所有节点
	while(p)
	{
		Student *next = p->pNext;
		free(p);
		p = next;
	}
	
}

void DataObj::add(Student* pNode)
{
	//指向每个节点的头部
	Student* p = &m_head;

	//通过头节点查找到链表尾部节点
	while (p)
	{
		if (p->pNext == NULL)
		{
			break;
		}
		p = p->pNext;
	}
	
	//添加节点到尾部
	p->pNext = pNode;
}
void DataObj::find(int age)
{
	//标记是否找到
	bool bFind = false;

	Student* p = &m_head;
	while(p)
	{
		if (p->age == age)
		{
			bFind = true;
			printNode(p);
		}
		p = p->pNext;
	}
	if (!bFind)
	{
		printf("没有找到该age的节点");
	}
}
void DataObj::printNode(Student* pNode)
{
	printf("name = %s, age = %d\n", pNode->name, pNode->age);
}

int main()
{
	//构造节点
	Student* pStu = (Student*) malloc(sizeof(Student));
	strcpy(pStu->name, "aaaa");
	pStu->age = 30;
	pStu->pNext = NULL;

	{
		DataObj dataObj;

		//添加节点
		dataObj.add(pStu);

		//查找节点
		dataObj.find(31);
	}

	return 1;
}

 

欢迎加群交流:C/C++开发交流

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农code之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值