极限复习c++
一、核心语法必背
1. 指针 vs 引用(简答题高频)
区别 | 指针 | 引用 |
---|---|---|
定义 | 存储地址的变量,可改指向 | 变量的别名,绑定后不可改 |
初始化 | 可空(nullptr )、延迟初始化 | 必须初始化,不能引用空值 |
访问 | 需解引用(*p /-> ) | 直接用变量名,语法同原变量 |
空值 | 允许nullptr | 无空引用,绑定后必有效 |
自增 / 减 | 支持(移动地址) | 不支持(别名不变) |
代码示例:
cpp
运行
int a = 10;
int* p = &a; // 指针存地址
int& ref = a; // 引用是别名 p = nullptr; // 指针可改指向
// ref = nullptr; // 错误!引用不能改绑定
2. 类与对象(必写代码)
封装 + 构造 / 析构 + 拷贝控制(考频最高):
cpp
运行
class Student {
private:string name;int age;
public:// 构造函数(重载 + 初始化列表)Student(string n = "无名", int a = 0) : name(n), age(a) {} // 拷贝构造(深拷贝场景需手动写,如含指针成员)Student(const Student& other) : name(other.name), age(other.age) {} // 析构函数(含动态内存时必写,如指针)~Student() { /* 释放资源 */ } // 成员函数void print() const { cout << "姓名:" << name << ",年龄:" << age << endl; }
};// 调用示例
Student zs("张三", 18);
zs.print();
Student ls = zs; // 调用拷贝构造
3. 继承与多态(必写代码)
虚函数 + 纯虚函数 + 多态调用(核心考点):
cpp
运行
class Animal {
public:// 纯虚函数(抽象类,强制派生类实现)virtual void speak() = 0; // 虚析构(避免派生类对象析构不完整)virtual ~Animal() {}
};class Dog : public Animal {
public:void speak() override { // override 显式重写cout << "汪汪!" << endl; }
};// 多态调用(基类指针/引用指向派生类对象)
Animal* animal = new Dog();
animal->speak(); // 输出“汪汪!”(运行时绑定)
delete animal;
4. 模板(必写代码)
函数模板 + 类模板(语法题高频):
cpp
运行
// 函数模板(泛型交换)
template <typename T>
void swap(T& a, T& b) {T temp = a;a = b;b = temp;
}// 类模板(简单栈)
template <typename T>
class Stack {
private:vector<T> data;
public:void push(const T& val) { data.push_back(val); }T pop() { T top = data.back();data.pop_back();return top; }
};// 调用示例
Stack<int> s;
s.push(10);
int x = s.pop();
5. 智能指针(必背区别)
类型 | 特点 | 场景 |
---|---|---|
unique_ptr | 独占所有权,不可拷贝 | 简单对象管理,避免资源泄漏 |
shared_ptr | 共享所有权(引用计数) | 多对象共享资源,需注意循环引用 |
weak_ptr | 弱引用(不影响计数) | 解决shared_ptr 循环引用 |
代码示例:
cpp
运行
// unique_ptr(独占)
unique_ptr<Student> p1 = make_unique<Student>("李四", 20);// shared_ptr(共享)
shared_ptr<Student> p2 = make_shared<Student>("王五", 22);
shared_ptr<Student> p3 = p2; // 引用计数+1// weak_ptr(弱引用)
weak_ptr<Student> p4 = p2; // 不影响计数
6. 异常处理(必写结构)
cpp
运行
try {// 可能抛异常的代码if (error) throw runtime_error("出错了!");
} catch (const runtime_error& e) {// 捕获特定异常cout << "错误:" << e.what() << endl;
} catch (...) {// 兜底捕获cout << "未知异常" << endl;
}
二、简答题速记(直接背答案)
1. 指针和引用的区别(必考题)
- 定义:指针存地址,可改指向;引用是别名,绑定后不可改。
- 初始化:指针可空、延迟初始化;引用必须初始化,不能引用空值。
- 访问:指针需解引用(
*p
);引用直接用变量名。 - 空值:指针允许
nullptr
;引用无空引用。
2. 虚函数的实现原理(必考题)
- 虚函数表(vtable):每个含虚函数的类编译时生成虚表,存储虚函数地址。
- 虚表指针(vptr):对象构造时,vptr 指向类的虚表。
- 调用机制:通过 vptr 查表,运行时动态绑定函数(多态的核心)。
3. 拷贝构造函数的调用场景(必考题)
- 用对象初始化新对象:
Student s2 = s1;
或Student s2(s1);
。 - 函数按值传递对象:
void func(Student obj)
,调用时拷贝实参。 - 函数返回对象(值返回):
Student func() { Student s; return s; }
,返回时拷贝临时对象。
4. 内存泄漏及解决方法(必考题)
- 内存泄漏:动态分配的内存(
new/malloc
)未释放,长期占用内存。 - 解决方法:
- 用智能指针(
unique_ptr
/shared_ptr
)自动管理。 - 严格配对
new/delete
、malloc/free
。 - 工具检测(如 Valgrind、AddressSanitizer)。
- 用智能指针(
5. 重载(overload)、覆盖(override)、重写(overwrite)区别(选考)
- 重载(overload):同一作用域,函数名相同,参数(类型 / 个数 / 顺序)不同,编译期决议。
- 覆盖(override):派生类重写基类虚函数,函数签名(名、参数、返回)完全一致,运行期多态。
- 重写(overwrite):非标准说法,常指覆盖(override)或隐藏基类函数(如派生类定义同名非虚函数)。
三、考试应急策略
- 代码题:优先写框架(类定义、函数模板结构),再补细节(构造函数、虚函数、智能指针)。
- 简答题:抓关键词(如 “虚函数表”“引用计数”“拷贝场景”),按点作答。
- 易错点:
- 多态必须用虚函数 + 基类指针 / 引用。
- 智能指针注意
unique_ptr
不可拷贝,shared_ptr
需避免循环引用。 - 模板代码记得写
template <typename T>
。
最后 1 小时:快速过一遍必背代码(类、多态、模板)和简答题答案,强化肌肉记忆!
祝考试顺利,代码全 AC !