构造函数,析构函数初级

        构造函数:

        构造函数的概念如下:

对于如下的类:

#include<iostream>
using namespace std;

class Data
{
public:
	void Init(int year,int month,int day)
	{
		_year = year;
		_month = month;
		_day = day;
	}
	void Print()
	{
		cout << _year << "-" << _month << "-" << _day << endl;
	}

 
private:  //私有
	int _year;
	int _month;
	int _day;

};


int main()
{
	Data d1;
	d1.Init(2024, 4, 18);
	d1.Print();
	
	Data d2;
	d2.Init(2023, 7, 3);
	d2.Print();

	return 0;
}

 对于Data类,我们可以利用公有的Init函数来对成员设置日期,但是如果每次都这样调用,是否会感觉有一些麻烦,那么我们想一想,能否在创建对象时,就将信息设置进去。

  构造函数是一个特殊的成员函数,名字与类相同,创建类类型对象时由编译器自动调用,用来保证每个数据成员都有一个合适的初始值,并且在对象整个生命周期只调用一次。

构造函数是一个特殊的成员函数,需要注意,构造函数虽然名字叫构造,但是构造函数主要的任务不是开辟空间创造对象,而是初始化对象。

class Data
{
public:
	Data()
	{
		_year = 1;
		_month = 1;
		_day = 1;
	}//这里是无参构造

	Data(int year, int month, int day)
	{
		_year = year;
		_month = month;
		_day = day;
	} //这里是带参构造

	void Print()
	{
		cout << _year << "-" << _month << "-" << _day << endl;
	}


private:  //私有
	int _year;
	int _month;
	int _day;

};


int main()
{
	Data d1; //这里并没有参数,选择无参构造
	d1.Print(); 

	Data d2(2024,4,18); //这里给了参数,选择带参构造 
	d2.Print();

	return 0;
}

构造函数呢,也分两种,一种是无参构造,和带参构造

运行图如下:

可能有人会问函数名一样的话会不会出现问题呢,答案是不会的,详细的可以看我们的函数重载。

构造函数的特征如下:

        1.函数名与类名相同。

        2.没有返回值(不是void,就是什么也不写)

        3.对象实例化时,编译器自动调用对应的构造函数。

        4.构造函数可以重载。

        5.如果类中没有显示定义构造函数,C++编译器会自动生成一个无参的默认构造函数,一旦用户显示定义,编译器将不再生成。

那么有人会问,第五点什么意思呢?

        就是如果你创建了一个构造函数,编译器是按照你的构造函数进行数据初始化的,如果你没有创建一个构造函数,那么C++的编译器是会自动给你生成一个无参的默认构造函数,那么默认构造函数会给我们的数据初始化成什么呢”?下面我们将我们创建的构造函数注释了试一下,看看会什么样。

        可以看到,我们将我们设置的构造函数注释掉的话,编译器会自动给我们生成一个不带参数的构造函数,但是这个数是随机的,可能并不是我们想要的值。 

        6.如果不实现构造函数的情况下,编译器会生成默认的构造函数,但是看起来默认构造函数又没啥用,因为它是随机值,也就是说在编译器生成的默认构造函数没有什么用?

        其实C++把类型分为:内置类型(基本类型)和自定义类型,内置类型就是语言提供的数据类型,如:int,char,long,short,double......,自定义类型就是我们使用的class/struct/union等自己定义的类型,我们看一下下面的程序,就会发现编译器生成的默认构造函数会对 _t调用它的默认构造函数

class Time
{
public:
	Time()
	{
		cout << "Time()" << endl;
		_hour = 1;
		_minute = 1;
		_second = 1;
	}
private:
	int _hour;
	int _minute;
	int _second;
};


class Data
{
public:

	void Print()
	{
		cout << _year << "-" << _month << "-" << _day << endl;
	}


private:  //私有
	int _year;
	int _month;
	int _day;

	Time _t;
};


int main()
{
	Data d1;
	d1.Print();

	return 0;
}

运行截图如下: 

可以看到,我们的_t中的内容确实是被初始化了。

这是因为:在C++11中针对内置类型成员不初始化的缺陷,又打了补丁,即:内置类型成员变量在类中声明可以给默认值。 

7.无参的构造函数和全缺省的构造参数都称为默认构造函数,并且默认构造函数只能有一个。

注意:无参构造函数、全缺省构造函数、我们没写编译器生成的构造函数,都可以认为是默认构造函数。

析构函数:

        析构函数的概念是与构造函数相反的,析构函数不是完成对对象本身的销毁,局部对象销毁工作是由编译器完成的,而对象在销毁时会自动调用析构函数,完成对象中资源的清理工作。

析构函数的特性:

        析构函数是特殊成员函数,特征如下:

        1.析构函数是在类名前加上字符~。

        2.无参数无返回类型。

        3.一个类只能有一个析构函数,若未显示定义,系统会自动生成默认的析构函数,注意:析构函数不能重载,会产生歧义。

        4.对象声明周期结束时,C++编译系统系统自动调用析构函数。

今天我们先介绍这么多,希望大家多多支持,未来会继续更新C++相关知识、感谢大家的观看 

  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: "undefined reference to constructor/destructor" 是编译器给出的一种错误信息,通常是由于没有找到该类的构造函数析构函数的定义导致的。这通常发生在以下情况: 1. 类的头文件未包含,导致编译器无法识别该类。 2. 构造函数/析构函数的定义与声明不一致,导致编译器无法识别。 3. 在类外定义了构造函数/析构函数,但是未在头文件中声明,导致编译器无法识别。 解决方案: 1. 检查包含的头文件是否正确,确保类的头文件已包含。 2. 检查构造函数/析构函数的定义与声明是否一致,修正不一致的地方。 3. 在类的头文件中声明构造函数/析构函数。 ### 回答2: 当编译器发现一个"undefined reference to"的错误时,通常意味着代码中引用但未定义的函数。而在构造函数析构函数的情况下,这可能是因为以下原因导致的错误: 1. 构造函数析构函数的声明与定义不匹配:代码中声明了一个构造函数析构函数,但没有提供与该声明匹配的实现。这可能是因为构造函数析构函数的名称、参数列表或返回类型与定义不匹配,导致编译器无法找到相应的定义。要解决这个问题,我们需要确保所有构造函数析构函数的声明和定义是匹配的,包括名称、参数列表和返回类型。 2. 构造函数析构函数的定义缺失:在某些情况下,可能会在代码中声明构造函数析构函数,但没有提供相应的定义。这种情况下,编译器在链接阶段无法找到构造函数析构函数的定义,从而报错。要解决这个问题,我们需要确保所有构造函数析构函数都有相应的实现,即提供与其声明匹配的定义。 综上所述,当出现"undefined reference to 构造函数 析构函数"的错误时,通常是因为构造函数析构函数的声明与定义不匹配,或者缺少相应的定义。通过检查代码并确保所有构造函数析构函数的声明和定义匹配,我们可以解决这个错误。 ### 回答3: 在编程中,当我们在使用一个类的构造函数析构函数时,有时候会遇到"undefined reference to 构造函数 析构函数"的错误。这个错误发生在链接阶段,通常是由于以下几种情况导致的: 1. 构造函数析构函数未定义:编译器找不到对应的构造函数析构函数的定义。要解决该问题,需要在实现文件中提供对应的定义,确保在使用时能够找到定义的实现。 2. 构造函数析构函数的定义与声明不匹配:在类的声明中声明并未提供参数列表,但在定义时提供了参数列表,或者反之。要解决该问题,需要检查类的声明和定义是否一致,确保参数列表的匹配。 3. 构造函数析构函数的访问权限不正确:如果构造函数析构函数在类的声明中被声明为私有的,而在调用时却被当作公有的进行访问,就会出现该错误。要解决该问题,需要检查类的访问权限,确保在使用时能够正确访问。 4. 构造函数析构函数的定义未被编译到可执行文件中:检查是否在编译过程中将实现文件添加到了编译器的编译选项中,确保构造函数析构函数的实现能够被编译和链接到可执行文件中。 总结来说,当编译器在链接阶段遇到"undefined reference to 构造函数 析构函数"的错误时,需要检查构造函数析构函数的定义和声明是否一致,确保可执行文件中能正确找到这些函数的实现。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小王的创意工坊

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

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

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

打赏作者

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

抵扣说明:

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

余额充值