本系列 C++ 相关文章 仅为笔者学习笔记记录,用自己的理解记录学习!C++ 学习系列将分为三个阶段:基础篇、STL 篇、高阶数据结构与算法篇,相关重点内容如下:
- 基础篇:类与对象(涉及C++的三大特性等);
- STL 篇:学习使用 C++ 提供的 STL 相关库;
- 高阶数据结构与算法篇: 手动实现自己的 STL 库 及 设计实现高阶数据结构,如 B树、B+树、红黑树等。
学习集:
- C++ 入门到入土!!!学习合集
- Linux 从命令到网络再到内核!学习合集
本期内容:C++ 类的基本成员函数:类类型成员与构造函数问题
目录:
1. 问题引入
2. 类类型成员(自定义数据类型)的初始化与构造函数
3. 类的两种定义方式
- - 3.1 内联式定义
- - 3.2 成员函数声明定义分离式定义【推荐】
4. 类中成员变量的命名建议
5. 简单对比C++中类与结构体的区别
6. 相关文章推荐
【 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++ 类的基本成员函数:构造函数基本的定义与调用 |(无参构造与有参构造及缺省参数式构造)