In computer science, manifest typing is explicit identification by the
software programmer of the ''type'' of each variable being declared. For example: if variable ''X'' is going to store integers then its ''type'' must be declared as integer. The term "manifest typing" is often used with the term
latent typing to describe the difference between the
static,
compile-time type membership of the object and its
run-time type identity.
In contrast, some programming languages use ''implicit typing'' (a.k.a.
type inference
Type inference refers to the automatic detection of the type of an expression in a formal language. These include programming languages and mathematical type systems, but also natural languages in some branches of computer science and linguistics. ...
) where the type is deduced from context at compile-time or allow for
dynamic typing
In computer programming, a type system is a logical system comprising a set of rules that assigns a property called a type to every "term" (a word, phrase, or other set of symbols). Usually the terms are various constructs of a computer progra ...
in which the variable is just declared and may be assigned a value of any type at runtime.
Examples
Consider the following example written in the
C programming language
''The C Programming Language'' (sometimes termed ''K&R'', after its authors' initials) is a computer programming book written by Brian Kernighan and Dennis Ritchie, the latter of whom originally designed and implemented the language, as well as ...
:
#include
int main(void)
Note that the variables ''s'', ''x'', and ''y'' were declared as a character array, floating point number, and an integer, respectively. The type system rejects, at compile-time, such fallacies as trying to add ''s'' and ''x''.
In contrast, in
Standard ML
Standard ML (SML) is a general-purpose, modular, functional programming language with compile-time type checking and type inference. It is popular among compiler writers and programming language researchers, as well as in the development of ...
, the ''types'' do not need to be explicitly declared. Instead, the ''type'' is determined by the type of the assigned expression.
let val s = "Test String"
val x = 0.0
val y = 0
in print "Hello, World!\n"
end
There are no manifest types in this program, but the compiler still ''infers'' the types
string
,
real
and
int
for them, and would reject the expression
s+x
as a compile-time error.
External links
Manifest typing
Type systems
{{compu-lang-stub