C++默认参数静态绑定
先来看这样一段代码
class Base
{
public:
virtual void print(int a = 1) const
{
std::cout << "Base " << a << "\n";
}
};
class Derived : public Base
{
public:
virtual void print(int a = 2) const override
{
std::cout << "Derived " << a << "\n";
}
};
请问:若按如下方式调用,会输出什么?
Base *p = new Derived();
p->print();
答案:输出 Derived 1
(而非 Base 1
或 Derived 2
)。
原因:
- 虚函数动态绑定,在运行时根据对象的实际类型决定调用哪个函数,因此这里调用的函数为
Derived::print
。 - 默认实参静态绑定,在编译期根据指针的声明类型决定默认实参的值,因此这里的
p->print()
相当于p->print(1)
。
因此,重写基类函数时不要重新定义函数的默认参数,以避免出现上文中的坑。
参考资料:
【推荐】2025 HarmonyOS 鸿蒙创新赛正式启动,百万大奖等你挑战
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】开源 Linux 服务器运维管理面板 1Panel V2 版本正式发布
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 还在手写JSON调教大模型?.NET 9有新玩法
· 复杂业务系统线上问题排查过程
· 通过抓包,深入揭秘MCP协议底层通信
· 记一次.NET MAUI项目中绑定Android库实现硬件控制的开发经历
· 糊涂啊!这个需求居然没想到用时间轮来解决
· Coze Studio:字节跳动 Coze 的开源版本来了!第一时间深度解析
· 为大模型 MCP Code Interpreter 而生:C# Runner 开源发布
· 复杂业务系统线上问题排查过程
· 独立开发:高效集成大模型,看这篇就够了
· 在SqlSugar的开发框架的Vue3+ElementPlus前端中增加对报表模块的封装处理,实现常