当前位置: 首页 > ai >正文

C++:⾯向对象的三⼤特性

面向对象的三大特性:

继承:允许一个类(子类 / 派生类)继承另一个类(父类 / 基类)的属性和方法,实现代码复用和层次化设计。
封装:将数据(成员变量)和操作数据的函数(成员函数)捆绑在一起,通过访问控制隐藏内部实现细节,仅对外提供必要接口。
多态:允许不同类的对象通过相同的接口进行调用,根据对象实际类型执行不同实现,增强代码灵活性和可扩展性。

访问修饰符:

public:成员可被任意类访问。
private:成员只能被本类的成员函数访问(默认修饰符)。
protected:成员可被本类和子类的成员函数访问。

多重继承

一个子类同时继承多个父类的特性。例如:

class A {};
class B {};
class C : public A, public B {}; // C继承自A和B

重载(Overload)和重写(Override)的区别:

重载:同一作用域内,函数名相同但参数列表不同(参数类型、个数或顺序),与返回值类型无关。编译时根据调用参数决定执行哪个版本。
重写:存在于继承关系中,子类重新定义父类的虚函数(函数签名完全相同)。运行时根据对象实际类型决定执行哪个版本(动态绑定)。

C++ 多态的实现:

通过虚函数(Virtual Function)和指针 / 引用实现。父类声明虚函数,子类重写该函数,当通过父类指针 / 引用调用虚函数时,实际执行的是对象所属子类的版本。例如:

class Shape {
public:virtual void draw() { cout << "Shape" << endl; }
};
class Circle : public Shape {
public:void draw() override { cout << "Circle" << endl; } // 重写虚函数
};
// 使用:
Shape* ptr = new Circle();
ptr->draw(); // 输出 "Circle"

成员函数 / 成员变量 / 静态成员函数 / 静态成员变量的区别:

成员变量:每个对象独享一份,存储对象的状态。
成员函数:绑定到对象,可访问对象的成员变量和其他成员函数。
静态成员变量:所有对象共享一份,存储类级别的数据,需在类外初始化。
静态成员函数:不绑定到对象,只能访问静态成员变量和其他静态成员函数,通过类名直接调用。

构造函数和析构函数:

构造函数:与类同名,无返回值,用于对象初始化,创建对象时自动调用。
析构函数:与类同名前加~,无返回值,用于资源释放(如内存、文件句柄等),对象销毁时自动调用。

构造函数的类型及作用:

默认构造函数:无参数或全默认参数,用于创建默认状态的对象。
参数化构造函数:带参数,用于自定义对象初始值。
拷贝构造函数:参数为同类对象的引用,用于创建新对象并复制已有对象的值(浅拷贝 / 深拷贝)。
移动构造函数:C++11 引入,参数为右值引用,用于高效转移资源所有权。

虚函数和虚函数表:

虚函数:在基类中用virtual声明的函数,允许子类重写,实现动态绑定。
虚函数表:每个包含虚函数的类都有一个虚函数表,存储该类的虚函数地址。每个对象包含一个指向虚函数表的指针(vptr),运行时通过 vptr 找到实际要调用的函数。

虚函数和纯虚函数的区别:

虚函数:基类中声明并实现,子类可选择性重写,基类可实例化。
纯虚函数:基类中声明但不实现(virtual void func() = 0;),子类必须重写,包含纯虚函数的类是抽象类,不可实例化。

抽象类和纯虚函数:

抽象类:包含至少一个纯虚函数的类,仅作为接口存在,不能实例化,必须通过子类实现纯虚函数后才能使用。
纯虚函数:定义接口规范,强制子类实现特定功能。

虚析构函数及其作用:

虚析构函数:基类的析构函数声明为virtual,确保通过基类指针删除派生类对象时,先调用子类析构函数,再调用基类析构函数,防止内存泄漏。
示例:

class Base {
public:virtual ~Base() { cout << "Base destructor" << endl; }
};
class Derived : public Base {
public:~Derived() override { cout << "Derived destructor" << endl; }
};
// 使用:
Base* ptr = new Derived();
delete ptr; // 输出 "Derived destructor" -> "Base destructor"

为什么要虚析构,不能虚构造:

虚析构:防止通过基类指针删除派生类对象时,只调用基类析构函数导致子类资源泄漏。
不能虚构造:构造函数用于创建对象并初始化 vptr,此时对象尚未完全构造,无法实现动态绑定。

不能声明为虚函数的函数:

构造函数
静态成员函数(不依赖对象)
内联函数(编译时展开,不支持动态绑定)
友元函数(非类成员)

深拷贝和浅拷贝的区别:

浅拷贝:复制对象时仅复制成员变量的值,若包含指针,则只复制指针地址,导致多个对象共享同一块内存,可能引发内存泄漏或悬空指针。
深拷贝:复制对象时不仅复制值,还为指针成员分配新内存并复制内容,每个对象拥有独立资源,避免内存问题。

运算符重载:

允许自定义类对内置运算符(如+, -, =, []等)的行为。
形式:返回类型 operator运算符(参数列表)
示例:重载+运算符实现复数加法:

class Complex {
private:double real, imag;
public:Complex operator+(const Complex& other) const {return Complex(real + other.real, imag + other.imag);}
};

先完成再完美,先记住这些,实践起来就会记住了!!!

http://www.xdnf.cn/news/7078.html

相关文章:

  • Java正则表达式:从基础到高级应用全解析
  • ColorAid —— 一个面向设计师的色盲模拟工具开发记
  • 超越想象:利用MetaGPT打造高效的AI协作环境
  • Vue 3 中使用 md-editor-v3 的完整实例markdown文本
  • Pandas 构建并评价聚类模型② 第六章
  • 实现菜谱二级联动导航
  • ubuntu防火墙命令和放行ssh端口
  • 03 Nginx日志格式及可视化
  • Estimation(估算):业务分析师的“不确定性对抗术”
  • LeetCode Hot100刷题——除自身以外数组的乘积
  • 【设计模式】- 行为型模式2
  • 时序数据库、实时数据库与实时数仓:如何为实时数据场景选择最佳解决方案?
  • 【Linux】第十八章 调优系统性能
  • 结构体对齐三大法则
  • UART、SPI、IIC复习总结
  • 获取Class的方式有哪些?
  • 蓝桥杯19681 01背包
  • 医学影像开发的开源生态与技术实践:从DCMTK到DICOMweb的全面探索
  • NC61 两数之和【牛客网】
  • 写spark程序数据计算( 数据库的计算,求和,汇总之类的)连接mysql数据库,写入计算结果
  • COCO数据集神经网络性能现状2025.5.18
  • 【数据结构】2-3-4 单链表的建立
  • 大学量化投资课程
  • C 语言学习笔记(函数)
  • 华为OD机试真题——最小循环子数组 (2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
  • 2025/5/18
  • 非线性1 修改
  • Jsoup库和Apache HttpClient库有什么区别?
  • 数据库DDL
  • 普通用户的服务器连接与模型部署相关记录