- Yo-yo problem
In
computer science , the yo-yo problem is ananti-pattern that occurs when a programmer has to read and understand a program whoseinheritance graph is so long and complicated that the programmer has to keep flipping between many different class definitions in order to follow the control flow of the program. It often happens inobject-oriented programming . The term comes from comparing the bouncing attention of the programmer to the up-down movement of a toyyo-yo .Most practices of object-oriented programming recommend keeping the inheritance graph as shallow as possible, in part to avoid this problem. The use of composition instead of inheritance is also strongly preferred, although this still requires that a programmer keep multiple class definitions in mind at once.
More generally, the yo-yo problem can also refer to any situation where a person must keep flipping between different sources of information in order to understand a concept. See Design Patterns, Chapter 1 summary, for additional information.
Object-oriented design techniques such as documenting layers of the inheritance hierarchy can reduce the effect of this problem, as they collect in one place the information that the programmer is required to understand.
ee also
*
Complexity What it means for a system (of any sort) to be complex
*Hrair limit The suggestion that humans can entertain at most approximately seven concepts at once
*Implementation inheritance
*Inheritance semantics
*Virtual Inheritance (object-oriented programming)
Wikimedia Foundation. 2010.