Overview of Polymorphism -多態的分類

多態有類型系統衍生。html

有限類型、無限類型、肯定類型。app

Classificationsoop

Christopher Strachey (1967) introduced the concept of polymorphism informally into procedural programming languages by distinguishing functionsui

  • that work differently on different argument types
  • that work uniformly on a range of argument types 

He defined the former as ad-hoc polymorphism and the latter as parametric polymorphism:3d

"Ad-Hoc polymorphism is obtained when a function works, or appears to work, on several different types (which may not exhibit a common structure) and may behave in unrelated ways for each type.  Parametric polymorphism is obtained when a function works uniformly on a range of types; these types normally exhibit some common structure." (Strachey, 1967)code

polymorphism

Cardelli and Wegner (1985) expanded Strachey's distinction to accommodate object-oriented languages.  They distinguished functionsorm

  • that work on a finite set of different and potentially unrelated types
    • coercion
    • overloading
  • that work on a potentially infinite number of types across some common structure
    • inclusion
    • parametric

adhoc polymorphism

Inclusion polymorphism is specific to object-oriented languages.htm

 

https://scs.senecac.on.ca/~oop244/pages/content/adhoc.htmlblog

 

 

 

Level 1 - universal vs, ad hoc polymorphism

    • functions that are universally polymorphic work uniformly for an infinite set of types
      all of which have some common structure
       
      • execute the same code for all admissible types
         
    • An ad hoc polymorphic function is just a syntactic abbreviation for small set of
      different monomorphic functions.
       

 

http://www.cs.kent.edu/~durand/CS43101Fall2004/DT-TypeSystems.htmlci

相關文章
相關標籤/搜索