我有一个派生类,我希望其中一个函数在基类中覆盖其版本,但具有不同的签名。简单的例子:
#include "stdio.h"
bool use_foo = false;
class Foo {
public:
virtual int func(double x) { printf ("%f in Foo!\n", x); }
};
class Bar : public Foo {
public:
int func(short x) { printf ("%d in Bar!\n", x); }
};
int main () {
Foo* A;
if (use_foo)
A = new Foo;
else
A = new Bar;
A->func(2);
return 0;
}
即使 A 被分配为派生类,上面的代码也会调用基类副本:
> g++ test.cpp -o test -O3 && ./test
2.000000 in Foo!
因为(据我的理解)参数可以转换为匹配基类签名,并且派生类不会因为这种差异而覆盖它(但在这种情况下它不会隐藏它吗?)。如果我将基类函数也更改为具有short
参数,则派生类确实设法覆盖它。
有没有一种简单的方法来说服调用基于指针使用正确的函数?我可以像这样添加另一个函数:
class Bar : public Foo {
public:
int func2(short x) { printf ("%d in Bar!\n", x); }
int func(double x) { func2(x); }
};
但是我会一直转换参数(short->double->short),这个函数对性能至关重要。有没有更好的办法?