C++多态笔记

提示:本文是个人学习C++多态的笔记,如有错误或看法请评论区讨论。参考文章链接见文尾。

目录

前言

一、怎么实现多态?

二、关于虚函数

1.定义和使用

2.构成多态条件

3.什么是虚函数表

总结


前言

多态性是面向对象程序设计的重要特征之一。多态实现原理:一个接口,多种方法


一、怎么实现多态?

函数重载、模板函数、虚函数(函数覆盖)

多态分为静态多态和动态多态,静态多态通过重载和模板技术实现,在编译时确定。动态多态通过虚函数和继承关系来实现,执行动态绑定,在运行时确定。运行时在虚函数表中寻找调用函数的地址。

二、关于虚函数

1.定义和使用

在基类前加virtual关键字,在派生类中重写该函数。

用关键字申明的函数就叫虚函数,存在虚函数的类都有一个一维的虚函数表。当类中声明虚函数时,编译器会在类中生成一个虚函数表。

只有派生类的虚函数覆盖掉基类的虚函数才能构成多态(通过基类指针访问派生类函数)。

构造函数不能是虚函数,析构函数可以。

如果一个函数在基类中被声明成虚函数,则它所在派生类中都是虚函数。只有通过基类指针或者调用虚函数才能引发动态绑定。(虚函数不能声明成静态)

2.构成多态条件

  • 必须存在继承关系
  • 继承关系中必须有同名虚函数,且是覆盖关系
  • 存在基类指针,可以用该指针调用派生类的虚函数(基类指针只能访问从基类继承过去的成员,派生类新增的不可访问)

3.什么是虚函数表

虚函数表是一个存储成员函数指针的数据结构,通过一块连续的内存来存储虚函数的地址,是由编译器自动生成和维护。同一个类的多个对象的虚函数表是同一个。父类对象的指针指向父类对象调用的是父类虚函数,指向子类调用的是子类虚函数。


总结

C++借助虚函数实现动态多态,其中派生类的虚函数覆盖掉基类虚函数才能构成多态。编译器通过生成虚函数表来管理维护类中虚函数的地址。

参考:

​​​​​​​C++多态的实现原理_程序​​​​​​猿王老铁的博客-优快云博客_c++多态原理

C++如何实现多态 - wsw_seu - 博客园 (cnblogs.com)

<think>嗯,用户提到在WSL中使用Tab键进行命令联想时会卡死,但路径补全正常。首先,我需要理解问题的具体情况。可能的原因有很多,我需要一步步分析。 首先,考虑WSL版本。用户可能使用的是WSL1,因为WSL1和WSL2在处理文件系统时有差异。WSL1的I/O性能较差,尤其是访问Windows文件系统时,可能导致Tab补全卡顿。这时候建议用户升级到WSL2,看看是否有改善。 接下来,检查自动补全相关的配置文件,比如.bashrc或.zshrc。如果用户自定义了一些补全脚本,可能存在冲突或者效率低下的代码。例如,某些插件或者别名可能加载缓慢。这时候建议用户备份配置文件后,暂时注释掉部分代码,逐步排查问题。 然后,考虑文件系统的问题。如果当前目录包含大量文件或符号链接,Tab补全时需要枚举所有文件,可能导致延迟甚至卡死。这时候可以建议用户切换到其他目录测试,或者调整目录结构减少文件数量。 另外,Bash版本或补全包的问题也可能导致卡顿。建议用户更新bash和bash-completion包,确保使用的是最新版本。如果问题依旧,尝试重新安装这些包。 还有可能是第三方工具的影响,比如防病毒软件或者Windows的实时保护功能在扫描WSL进程,导致延迟。可以建议用户暂时禁用这些安全软件,测试是否有改善。 资源不足也是一个可能的原因,比如内存或CPU占用过高。检查系统资源使用情况,关闭不必要的程序,释放资源。 如果上述方法都无效,可能需要重置WSL环境或者创建新的发行版实例来测试是否是环境损坏导致的问题。 最后,建议用户根据具体情况逐一尝试这些解决方案,定位问题根源。如果还是无法解决,提供详细的日志或错误信息会有助于进一步诊断。</think>关于WSL中按Tab键进行命令联想卡死但路径补全正常的问题,以下是逐步分析及解决方案: --- ### **1. 问题定位** 首先需明确卡死现象的特征: - **仅命令联想卡死**:如输入`git`后按Tab补全子命令时卡顿 - **路径补全正常**:如输入`cd /u`按Tab补全为`/usr/`时正常 - **可能伴随高CPU/内存占用** --- ### **2. 常见原因** #### **(1) WSL文件系统差异** - **WSL1与WSL2差异**: - WSL1的`/mnt/`目录(挂载的Windows驱动器)I/O性能较差 - 在Windows目录下执行补全时,文件枚举速度慢 - ✅ 解决方案:迁移到WSL2(执行`wsl --set-version <发行版> 2`) #### **(2) 自动补全配置冲突** - **Bash补全包问题**: - 某些第三方补全脚本(如`bash-completion`)可能存在低效代码 - 自定义的`.bashrc`或`.zshrc`中添加了复杂补全逻辑 - ✅ 临时测试:新建一个用户环境测试 ```bash # 新建测试用户 sudo useradd testuser sudo -u testuser -i # 在新环境中尝试Tab补全 ``` #### **(3) 特殊符号链接** - **递归符号链接**: - 当前目录中存在循环符号链接(如`ln -s . loop`) - Tab补全会尝试遍历所有子目录 - ✅ 解决方案:检查并删除异常符号链接 --- ### **3. 分步排查** #### **步骤1:验证WSL版本** ```bash # 查看WSL版本 wsl.exe --list --verbose # 若为WSL1,建议升级到WSL2 wsl.exe --set-version <发行版名称> 2 ``` #### **步骤2:简化Shell配置** ```bash # 备份配置文件 cp ~/.bashrc ~/.bashrc.bak # 清空配置测试 echo "" > ~/.bashrc # 重新加载环境 exec bash ``` #### **步骤3:检查补全包状态** ```bash # 更新软件包 sudo apt update && sudo apt upgrade -y # 重新安装bash-completion sudo apt install --reinstall bash-completion ``` --- ### **4. 高级调试** #### **(1) 追踪补全过程** ```bash # 启用调试模式 set -x # 执行补全操作(观察输出卡顿点) set +x # 关闭调试 ``` #### **(2) 检查系统日志** ```bash # 查看内核日志(需Windows端配合) dmesg | grep -i "error" ``` --- ### **5. 替代方案** 如果问题仍未解决,可尝试: 1. **切换Shell**:改用`zsh`+`oh-my-zsh` ```bash sudo apt install zsh sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" ``` 2. **手动补全工具**:使用`fzf`模糊搜索 ```bash sudo apt install fzf # 绑定Ctrl+R搜索历史命令 ``` --- ### **总结建议** | 现象 | 优先级 | 解决方案 | |------|--------|----------| | WSL1下操作Windows目录卡顿 | 高 | 升级到WSL2 | | 自定义配置冲突 | 中 | 清理`.bashrc` | | 文件系统异常 | 低 | 检查符号链接 | 若以上方法无效,建议提供以下信息进一步诊断: - WSL发行版名称及版本(Ubuntu 22.04? Debian?) - 执行`echo $BASH_VERSION`的输出 - 卡顿时使用`top`命令的CPU/内存占用截图
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值