guys I know this question is very basic but I've met in few publications (websites, books) different style of override virtual function. What I mean is: if I have base class:
class Base
{
public:
virtual void f() = 0;
};
in some publications I saw that to override this some authors would just say:
void f();     
and some would still repeat the virtual keyword before void. Which form of overwriting is in good style? Thank you for your answers.
This is purely a matter of taste. Some weak arguments can be made back and forth as to the self-documentation value of some styles versus the non-redundancy of others.
It is not necessary to add the virtual keyword to a method you override in a subclass as this qualifier can not be removed by omitting it in subclass declarations.
It is however good practise to repeat the virtual keyword as it documents which derived functions are virtual in the base class.
This is also recommended by the 'High Integrity C++ Coding Standard Manual'.
which is linked in the C++ FAQ.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With