Duck typing explained

In computer programming, duck typing is an application of the duck test - "If it walks like a duck and it quacks like a duck, then it must be a duck" - to determine whether an object can be used for a particular purpose. With nominative typing, an object is of a given type if it is declared as such (or if a type's association with the object is inferred through mechanisms such as object inheritance). With duck typing, an object is of a given type if it has all methods and properties required by that type.[1] [2] Duck typing may be viewed as a usage-based structural equivalence between a given object and the requirements of a type.

Example

This simple example in Python 3 demonstrates how any object may be used in any context until it is used in a way that it does not support.

class Duck: def swim(self): print("Duck swimming")

def fly(self): print("Duck flying")

class Whale: def swim(self): print("Whale swimming")

for animal in [Duck, Whale]: animal.swim animal.fly

Output:Duck swimmingDuck flyingWhale swimmingAttributeError: 'Whale' object has no attribute 'fly'If it can be assumed that anything that can swim is a duck because ducks can swim, a whale could be considered a duck; however, if it is also assumed that a duck must be capable of flying, the whale will not be considered a duck.

In statically typed languages

In some statically-typed languages such as Boo[3] and D,[4] [5] class type checking can be specified to occur at runtime rather than at compile time.

Comparison with other type systems

Structural type systems

Duck typing is similar to, but distinct from, structural typing. Structural typing is a static typing system that determines type compatibility and equivalence by a type's structure, whereas duck typing is dynamic and determines type compatibility by only that part of a type's structure that is accessed during runtime.

The TypeScript,[6] Elm[7] and Python[8] languages support structural typing to varying degrees.

Protocols and interfaces

Protocols and interfaces provide a way to explicitly declare that some methods, operators or behaviors must be defined. If a third-party library implements a class that cannot be modified, a client cannot use an instance of it with an interface unknown to that library even if the class satisfies the interface requirements. A common solution to this problem is the adapter pattern. In contrast, with duck typing, the object would be accepted directly without the need for an adapter.

Templates or generic types

Template (also called generic) functions or methods apply the duck test in a static typing context; this brings all of the advantages and disadvantages of static versus dynamic type checking. Duck typing can also be more flexible in that only the methods actually called at runtime must be implemented, while templates require implementations of all methods that cannot be proven unreachable at compile time.

In languages such as Java, Scala and Objective-C, reflection may be employed to inspect whether objects implement methods or add necessary methods at runtime. For example, Java's MethodHandle API can be used in this manner.[9]

See also

Notes and References

  1. Web site: Glossary — Python 3.7.1 documentation. docs.python.org. 2018-11-08.
  2. Web site: 2020-06-28. Python Duck Typing - Example. 2020-07-26. Techie Hours. en-US. 2022-03-31. https://web.archive.org/web/20220331075920/https://techiehours.com/python/python-duck-typing/. dead.
  3. http://boo.codehaus.org/Duck+Typing Boo: Duck Typing
  4. Web site: Dynamic classes and duck typing .
  5. Web site: Metaprogramming - duck typing in D .
  6. Web site: SE Radio Episode 384: Boris Cherny on TypeScript. se-radio.net. 2019-10-25.
  7. Web site: Core Language · An Introduction to Elm. Evan. Czaplicki. 30 January 2017.
  8. Web site: PEP 544 – Protocols: Structural subtyping (static duck typing).
  9. Web site: StackOverflow: Implement duck typing using java MethodHandles. 13 June 2020.