C++ 面向对象
一、C++三大特性记忆口诀三大特性记分明,封装继承多态行;封装数据和操作,权限控制安全定;继承复用加扩展,子类父类心相印;多态接口行为异,编译运行两类型。 核心概念 封装:数据与操作打包,通过访问权限控制暴露(public/private/protected),提高安全性,隐藏实现细节 继承:子类拥有父类属性和行为,可在原有基础上扩展,实现代码复用 多态:同一种接口不同行为,分编译时多态(函数重载、运算符重载)和运行时多态(虚函数+继承) 代码示例123456789101112131415161718192021222324252627#include <iostream>using namespace std;// 封装class Animal {protected: string name;public: Animal(string n) : name(n) {} virtual void speak() { // 虚函数实现多态 cout << name...
C++ 内存管理
一、智能指针记忆口诀:智能指针三兄弟,unique独占share共享,weak观测防循环,RAII思想记心上智能指针是一种自动管理动态内存的工具类,用于防止内存泄漏。C++提供了三种常用的智能指针: unique_ptr(独占智能指针): 独占对象所有权,同一时间只能有一个指针指向一个对象 禁止拷贝构造和拷贝赋值,支持移动语义 适合独占资源的场景 shared_ptr(共享智能指针): 共享对象所有权,允许多个指针指向同一个对象 使用引用计数,当引用计数为0时释放资源 可以通过use_count()查看引用计数 weak_ptr(弱引用指针): 不拥有资源,不增加引用计数 用于解决shared_ptr的循环引用问题 需要通过lock()方法提升为shared_ptr才能访问资源 RAII机制(资源获取即初始化): 当创建智能指针对象时,它立即接管资源 当智能指针生命周期结束时,自动调用析构函数释放资源 无需手动调用delete,有效防止内存泄漏 代码示例1234567891011121314//...
C++ 基础知识点整理
一、变量类型及其存储特性【记忆口诀】三变量,作用域不同;生命周期各有别,存储位置要分清1.1...
《C 和指针》学习:从底层原理到实战进阶
一、指针本质的深度剖析1.1 指针的内存映射机制指针变量在内存中占据固定大小的存储空间(取决于系统位数,32 位系统为 4 字节,64 位系统为 8 字节),其存储的数值是另一个内存单元的地址编码。这种地址编码与内存物理地址存在映射关系,操作系统通过内存管理单元(MMU)实现虚拟地址到物理地址的转换,而指针操作的始终是虚拟地址空间。 1.2 指针类型的约束作用指针的类型并非仅为语法约束,而是决定了指针运算的步长和解引用时的内存访问范围。例如: int *p:p++操作使地址增加sizeof(int),解引用时访问 4 字节内存 char *p:p++操作使地址增加 1 字节,解引用时访问 1 字节内存 这种类型约束是 C 语言类型安全的基础,也是避免内存越界的重要保障。 二、指针与数组的辩证关系2.1 数组名的双重属性数组名在多数语境下表现为 "指向首元素的指针常量",但存在两个例外: 作为sizeof运算符的操作数时,返回整个数组的字节大小(如sizeof(int [5])返回...
C语言数组与指针深度解析
引言:为什么需要理解数组与指针的差异?在C语言中,数组和指针是最基础且容易混淆的概念。尤其是*p[](指针数组)和(*p)[](数组的数组)的语法差异,涉及类型优先级、内存布局和操作方式的本质区别。本文通过具体代码示例,结合fruits1(二维数组)和fruits2(指针数组)的对比,深入解析两者的核心差异,并探讨实际开发中的应用场景。 核心概念:*p[]与(*p)[]的类型优先级C语言中,运算符优先级决定了表达式的解析顺序。其中,[](下标运算符)的优先级高于*(解引用运算符)。因此: *p[]会被解析为*(p[]),即数组的指针(指针数组):数组的每个元素是指针; (*p)[]会被解析为(*p)[],即数组的数组(二维数组):数组的每个元素是另一个数组。 用户代码中的fruits1和fruits2正是这两种类型的典型代表: 12char fruits1[][10] = { "apple", "banana", "cherry" }; // 二维数组(数组的数组)char...