HOME

TheInfoList



OR:

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