C++ 学习 ::【基础篇:13】:C++ 类的基本成员函数:类类型成员的初始化与构造函数问题

本系列 C++ 相关文章 仅为笔者学习笔记记录,用自己的理解记录学习!C++ 学习系列将分为三个阶段:基础篇、STL 篇、高阶数据结构与算法篇,相关重点内容如下:

  1. 基础篇类与对象(涉及C++的三大特性等);
  2. STL 篇学习使用 C++ 提供的 STL 相关库
  3. 高阶数据结构与算法篇手动实现自己的 STL 库设计实现高阶数据结构,如 B树、B+树、红黑树等。

学习集:


本期内容:C++ 类的基本成员函数:类类型成员与构造函数问题


前期内容: C++ 学习 ::【基础篇:12】:C++ 类的基本成员函数:构造函数基本的定义与调用 |(无参构造与有参构造及缺省参数式构造)


目录:
1. 问题引入
2. 类类型成员(自定义数据类型)的初始化与构造函数
3. 相关文章推荐


C++学习合集链接


1. 问题引入

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


优缺问题引出:

  • C++ 中,参数可分为:基本数据类型(int、double、(任意类型指针)…)和 自定义数据类型(struct、class、…)
  • C++ 对,这两种参数在自动生成无参构造时是不同的!!!
    • 对于基本数据类型,不做处理!
    • 对于自定义数据类型回去调用自定义数据类型的:默认构造函数!

【 以下示例为使用两个栈实现队列示例的构造函数探讨! 】

代码示例
#include<iostream>
using std::cout;
using std::endl;


typedef int DataType;

/* 定义一个栈的及其构造函数 */
class Stack {
public:
    Stack(int capacity = 4) {		// 结合参数缺省实现:只要实例化必定是可用的栈(空间为:4)
        _capacity = capacity;
        _array = (DataType*)malloc(sizeof(DataType) * capacity);	// 申请存储空间
        if (_array == nullptr) {
            perror("malloc fail!\n");
            return;
        }
        _size = 0;
    }
private:
    DataType* _array;			// 顺序存储方式
    int _capacity;			// 记录当前栈的最大存储量
    int _size;				// 记录当前栈中的元素个数
};

class Queue {
private:
    Stack _st1;
    Stack _st2;
};


int main() {
    Stack stk;
    Queue queue;
    return 0;
}

在这里插入图片描述


2. 类类型成员(自定义数据类型)的初始化与构造函数

由上示例代码可知:对于自定义数据类型会去调用自定义数据类型的构造函数!


这是 C++ 早期设计的一个缺陷:即对于C++的两种类型使用了两种原则进行处理!


C++ 11:后官方给出了一个补丁 / 解决方案:即自定义数据类型在成员变量的声明是可以赋默认值!【注意点:赋值不是在初始化,而是在指定缺省值!【给定缺省值实际是给构造函数的初始化列表处进行定义】】(代码如下!)

#include<iostream>
using std::cout;
using std::endl;

typedef int DataType;

/* 定义一个栈的及其构造函数 */
class Stack {					/* 不自定义构造函数 */
public:
private:
    DataType* _array;			
    int _capacity = 4;			// 不是初始化,而是相当于指定缺省值
    int _size = 0;				// 不是初始化,而是相当于指定缺省值
};

class Queue {
private:
    Stack _st1;
    Stack _st2;
};


int main() {
    Stack stk;
    Queue queue;
    return 0;
}

在这里插入图片描述


3. 相关文章推荐

1. C++ 学习 ::【基础篇:12】:C++ 类的基本成员函数:构造函数基本的定义与调用 |(无参构造与有参构造及缺省参数式构造)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

NPC的白话文谈

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

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

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

打赏作者

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

抵扣说明:

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

余额充值