Difference between revisions of "Intermediate C++ Game Programming Tutorial 18"
From Chilipedia
(→Video Timestamp Index) |
(→Video Timestamp Index) |
||
Line 17: | Line 17: | ||
* Create a free function that calls <code>SpecialMove()</code> on the instances of derived classes of MemeFighter [https://youtu.be/4Vvc1YurUYA?t=1m17s 0:23] | * Create a free function that calls <code>SpecialMove()</code> on the instances of derived classes of MemeFighter [https://youtu.be/4Vvc1YurUYA?t=1m17s 0:23] | ||
** This requires the member function <code>SpecialMove()</code> to be added to the base class... | ** This requires the member function <code>SpecialMove()</code> to be added to the base class... | ||
− | ** ... and the signatures of | + | ** ... and the signatures of these member functions in the derived classes to match up |
[https://youtu.be/cdOB_gKnJOM Tutorial 18.2] | [https://youtu.be/cdOB_gKnJOM Tutorial 18.2] |
Revision as of 03:30, 12 October 2019
Another two-parter here, and we got the real stuff now. Virtual functions allow you to unlock the true potential of inheritance in C++. You need to know this shit.
Contents
Topics Covered
Part 1
- How to create a virtual function
- Using the override keyword
- Creating a pure virtual function
- Using a container of pointers to manage a heterogeneous collection of objects
- virtual destructors
Part 2
- Using inheritance and composition together
- Basic idea of a polymorphic state machine and its application to entity behavior
Video Timestamp Index
- Create a free function that calls
SpecialMove()
on the instances of derived classes of MemeFighter 0:23- This requires the member function
SpecialMove()
to be added to the base class... - ... and the signatures of these member functions in the derived classes to match up
- This requires the member function
- WORK-IN-PROGRESS
Source Code
Errata
- Forgot the virtual destructor for
class Weapon
! (this one hurts) - In the children, the function signatures should be:
int CalculateDamage( const Attributes& attr,Dice& d ) const override
- Though not technically an error, it might have been a better decision to make
Weapon::GetName()
andWeapon::GetRank()
(pure) virtual functions (this would reduce the amount of per-instance data to just the vtable ptr)