Subtyping
Concept in type theory
Subtyping is a concept in type theory and programming languages that allows a given type to be substituted for another type. This is a fundamental aspect of polymorphism in object-oriented programming. Subtyping is often used to ensure that a program can handle different types of data in a flexible and reusable manner.
Definition[edit | edit source]
Subtyping is a relation between types, where one type (the subtype) is considered to be a specialized version of another type (the supertype). If a type S is a subtype of a type T, then an object of type S can be used wherever an object of type T is expected. This is known as the Liskov substitution principle.
Formalization[edit | edit source]
In formal type systems, subtyping is often defined using a set of rules that describe how types relate to each other. These rules are typically expressed in terms of a subtype relation, often denoted as S ≤ T, meaning S is a subtype of T.
Subtyping in Programming Languages[edit | edit source]
Subtyping is implemented in various ways across different programming languages. In Java, for example, subtyping is achieved through inheritance and interfaces. In C++, subtyping is implemented using classes and virtual functions.
Nominal vs. Structural Subtyping[edit | edit source]
Subtyping can be classified into two main categories: nominal subtyping and structural subtyping.
- Nominal subtyping is based on explicit declarations. A type is a subtype of another if it is explicitly declared to be so. This is common in languages like Java and C++.
- Structural subtyping is based on the structure of the types. A type is a subtype of another if it has the same structure or a compatible structure. This is used in languages like TypeScript and Go.
Covariance and Contravariance[edit | edit source]
Subtyping interacts with variance in type systems, particularly in the context of generic programming.
- Covariance allows a type to be substituted with a subtype. For example, if List<Dog> is a subtype of List<Animal>, then covariance is supported.
- Contravariance allows a type to be substituted with a supertype. For example, if Function<Animal> is a subtype of Function<Dog>, then contravariance is supported.
Applications[edit | edit source]
Subtyping is crucial in designing flexible and reusable software components. It allows developers to write code that can operate on objects of different types, enhancing code reuse and maintainability. Subtyping is also essential in design patterns such as the factory method pattern and the strategy pattern.
Related pages[edit | edit source]
Search WikiMD
Ad.Tired of being Overweight? Try W8MD's physician weight loss program.
Semaglutide (Ozempic / Wegovy and Tirzepatide (Mounjaro / Zepbound) available.
Advertise on WikiMD
WikiMD's Wellness Encyclopedia |
Let Food Be Thy Medicine Medicine Thy Food - Hippocrates |
Translate this page: - East Asian
中文,
日本,
한국어,
South Asian
हिन्दी,
தமிழ்,
తెలుగు,
Urdu,
ಕನ್ನಡ,
Southeast Asian
Indonesian,
Vietnamese,
Thai,
မြန်မာဘာသာ,
বাংলা
European
español,
Deutsch,
français,
Greek,
português do Brasil,
polski,
română,
русский,
Nederlands,
norsk,
svenska,
suomi,
Italian
Middle Eastern & African
عربى,
Turkish,
Persian,
Hebrew,
Afrikaans,
isiZulu,
Kiswahili,
Other
Bulgarian,
Hungarian,
Czech,
Swedish,
മലയാളം,
मराठी,
ਪੰਜਾਬੀ,
ગુજરાતી,
Portuguese,
Ukrainian
Medical Disclaimer: WikiMD is not a substitute for professional medical advice. The information on WikiMD is provided as an information resource only, may be incorrect, outdated or misleading, and is not to be used or relied on for any diagnostic or treatment purposes. Please consult your health care provider before making any healthcare decisions or for guidance about a specific medical condition. WikiMD expressly disclaims responsibility, and shall have no liability, for any damages, loss, injury, or liability whatsoever suffered as a result of your reliance on the information contained in this site. By visiting this site you agree to the foregoing terms and conditions, which may from time to time be changed or supplemented by WikiMD. If you do not agree to the foregoing terms and conditions, you should not enter or use this site. See full disclaimer.
Credits:Most images are courtesy of Wikimedia commons, and templates, categories Wikipedia, licensed under CC BY SA or similar.
Contributors: Prab R. Tumpati, MD