Утиная типизация

Материал из Википедии — свободной энциклопедии

Перейти к: навигация, поиск

Латентная, неявная или утиная типизация (калька с англ. Duck typing) — вид динамической типизации, применяемой в некоторых языках программирования (Smalltalk, Python, Ruby, Groovy, ColdFusion, Boo, C++ (для шаблонов)), когда границы использования объекта определяются его текущим набором методов и свойств, в противоположность наследованию от определёного класса. То есть считается, что объект реализует интерфейс, если он содержит все методы этого интерфейса, независимо от связей в иерархии наследования и принадлежности к какому-либо конкретному классу.

Название термина пошло от английского «duck test»тест на утку»), который в оригинале звучит как:

«If it walks like a duck and quacks like a duck, it must be a duck»
(«Если что-то ходит, как утка, и крякает, как утка, то это, должно быть, утка»).

Утиная типизация решает такие проблемы иерархической типизации, как:

  • невозможность явно указать (путем наследования) на совместимость интерфейса со всеми настоящими и будущими интерфейсами, с которыми он идейно совместим
  • чрезмерное увеличение числа связей в иерархии типов при хотя бы частичной попытке это сделать.

Шаблоны в Си++ реализуют статическую форму неявной типизации. Различные итераторы, например, не обязаны наследоваться от общего класса, но могут быть использованы в единой манере, если реализуют соответствующие методы.

Другим близким подходом является структурные подтипы в OCaml, где типы объектов совместимы, если совместимы сигнатуры их методов, независимо от объявленного наследования, причём всё это проверяется во время компиляции программы.

[править] Смотри также

Утиный тест

[править] Ссылки