C++复习类与对象基础

类的成员函数为什么需要在类外定义

1.1 代码组织与可读性​

​类内定义​:适合 ​短小简单的函数​(如 getter/setter),能直观体现类的接口设计。

​类外定义​:当函数体较复杂时,将实现移到类外(如 .cpp 文件)可保持 ​类声明简洁,便于快速理解类的核心接口,避免代码臃肿。

1.2 编译依赖与构建速度​

​类内定义​:若函数体直接写在头文件中,每次修改函数逻辑时,所有包含该头文件的代码都需要重新编译,导致 ​编译时间大幅增加。

​类外定义​:将实现放在 .cpp 文件中,修改实现时仅需重新编译该 .cpp 文件,显著提升大型项目的 ​构建效率。

1.3 避免重复定义(ODR 规则)​​

​类内定义​:若头文件被多个源文件包含,类内定义的成员函数会被视为 ​内联函数​(inline)。虽然内联允许重复定义,但过度使用可能导致 ​代码膨胀。

​类外定义​:在 .cpp 文件中定义函数,确保 ​仅有一份实现,严格遵循单一定义规则(One Definition Rule, ODR)。

1.4 封装与信息隐藏​

​类外定义​:可将实现细节隐藏在 .cpp 文件中,仅通过头文件暴露接口。这种方式 ​减少头文件暴露的内部信息,增强代码的封装性。

2.类内成员函数是否需要同时实现const版本和非const版本

2.1 非const对象可以调用const修饰的成员函数,但是const对象只能调用const成员变量

2.2 当const函数与非const函数代码逻辑几乎相同时

若两个版本的函数逻辑几乎相同(仅返回类型或对象 const 属性不同),可通过 复用代码​减少冗余

1.非const函数调用const函数

cpp 复制代码
class MyArray {
public:
    // const 版本实现核心逻辑
    const int& operator[](size_t index) const { 
        // 复杂逻辑(如边界检查)
        return data[index]; 
    }

    // 非 const 版本复用 const 版本,用 const_cast 移除返回类型的 const
    int& operator[](size_t index) {
        return const_cast<int&>( 
            static_cast<const MyArray&>(*this)[index] 
        );
    }
};

1.通过static_cast<const MyArray&>调用operator.[],如果返回值类型一个是const可通过const_cast<int&>进行类型转换

2.万能引用

cpp 复制代码
class MyArray {
private:
    template <typename Self>
    static auto& get_element(Self&& self, size_t index) {
        // 复杂逻辑(如边界检查)
        return self.data[index];
    }

public:
    int& operator[](size_t index) { 
        return get_element(*this, index); 
    }

    const int& operator[](size_t index) const { 
        return get_element(*this, index); 
    }
};

.*运算符

cpp 复制代码
class A
{
public:
	void func()
	{
		cout << "A::func()" << endl;
	}
};

//typedef void(A::*PF)(); //成员函数指针类型
using PF = void(A::*)();

int main()
{
	// C++规定成员函数要加&才能取到函数指针
	PF function = &A::func;
	A aa;
	(aa.*function)();
}

初始化列表初始化引用的问题

cpp 复制代码
class Myclass {
public:
	Myclass(int x):_x(x)
	{}
private:
	int& _x;
};


int main()
{
	Myclass a(1);
	return 0;
}

非const引用引用临时变量,编译器仅检查 ​直接引用绑定​ 的合法性(如 int& r = 1; 会报错),但无法追踪间接的悬垂引用风险。但是可以传字面量,但是成员变量是const int&,这样就可以延长生命周期,但最好将参数改为与成员变量相同的形参,如int &成员初始化传参就传int&,这样传字面量编译器也会警告

相关推荐
2501_9411118612 分钟前
C++模块化设计原则
开发语言·c++·算法
2501_9412375323 分钟前
基于C++的游戏引擎开发
开发语言·c++·算法
_OP_CHEN29 分钟前
算法基础篇:(十)贪心算法拓展之哈夫曼编码:从 “合并最优” 到数据压缩的传奇
c++·算法·贪心算法·蓝桥杯·哈夫曼编码·算法竞赛·acm/icpc
枫叶丹432 分钟前
【Qt开发】Qt窗口(二) -> QToolBar工具栏
开发语言·数据库·c++·qt
高山有多高1 小时前
堆应用一键通关: 堆排序 +TOPk问题的实战解析
c语言·数据结构·c++·算法
2501_941237451 小时前
高性能计算通信库
开发语言·c++·算法
1白天的黑夜11 小时前
递归-二叉树中的剪枝-814.二叉树剪枝-力扣(LeetCode)
c++·leetcode·剪枝·递归
杜子不疼.1 小时前
【C++】红黑树为什么比AVL快?用C++亲手实现告诉你答案
开发语言·c++
2501_941236213 小时前
C++与Node.js集成
开发语言·c++·算法
晨非辰3 小时前
【数据结构初阶系列】归并排序全透视:从算法原理全分析到源码实战应用
运维·c语言·数据结构·c++·人工智能·python·深度学习