Type System Fundamentals
Ballerina is a statically typed language.
That means that every variable has a type that is known at compile time.
Ballerina has structural type system.
A static type checker uses either the names or the structure of the types in order to compare them against other types. Checking against the name is nominal typing and checking against the structure is structural typing.
So in Ballerina, type compatibility is identified by considering the structure of the value rather than just relying on the name of the type.
All mainstream object-oriented languages use nominal subtyping. For ex: Java has no structural subtyping at all; all subtype relationships must be explicitly declared.
Ballerina has semantic subtyping.
The syntax - describes which strings of of characters comprise a valid program. i.e., the form of the language.
The semantics - describes what syntactically valid programs mean, what they do. i.e. the meaning of the language.
Semantic subtyping is an approach for defining subtyping relation based on set-theoretic models, rather than syntactic rules.
Type is a set of values. When is an assignment, x = y
legal?
There are at least two possible answers:
-
When
x
andy
are of equal typesStructural type checking decides that.
-
When
y
’s type can be “converted” tox
’s type- Once we consider types as set of values, we realize immediately one set may be a subset of another set.
- When the set of values in one type,
T
, is a subset of the set of values in another type,U
, we say thatT
is a subtype ofU
. - There are two main approaches for defining the subtyping relation:
- syntactic approach - it is defined by means of a formal system of deduction rules
- semantic approach - It is defined based on set theories. The subtyping relation is defined as inclusion of sets denoting types. Ballerina is using this approach.
Semantic subtyping is most useful for expressing types of tree-structured data, such as JSON.
Ballerina has network aware type system.
Ballerina’s type system is specifically focused on aiding the development of networked and distributed applications. It has constructs that seamlessly map to network programming concepts such as services and network resources.