In type theory, bounded quantification refers to universal or existential quantifiers which are restricted to range only over the subtypes of a particular type. Bounded quantification is an interaction of parametric polymorphism with subtyping. Bounded quantification has traditionally been studied in the functional setting of System F<:, but is available in modern object-oriented languages supporting parametric polymorphism such as Java, C# and Scala.
Overview
The purpose of bounded quantification is to allow for polymorphicfunctions to depend on some specific behaviour of objects instead of type inheritance. It assumes a record-based model for object classes, where every class member is a recordelement and all class members are named functions. Object attributes are represented as functions that take no argument and return an object. The specific behaviour is then some function name along with the types of the arguments and the return type. Bounded quantification allows to considers all objects with such a function. An example would be a polymorphic min function that considers all objects that are comparable to each other.
F-bounded quantification
F-bounded quantification or recursively bounded quantification, introduced in 1989, allows for more precisetyping of functions that are applied on recursive types. A recursive type is one that includes a function that uses it as a type for some argument or its return value.
Example
This kind of type constraint can be expressed in Java with a generic interface. The following example demonstrates how to describe types that can be compared to each other and use this as typing information in polymorphic functions. The Test.min function uses simple bounded quantification and does not preserve the type of the assigned types, in contrast with the Test.Fmin function which uses F-bounded quantification. In mathematical notation, the types of the two functions are where interface Comparable class Integer implements Comparable class String implements Comparable class Test