
In
computer science and
computer programming, a data type (or simply type) is a set of possible values and a set of allowed operations on it. A data type tells the
compiler or
interpreter how the programmer intends to use the data. Most programming languages support basic data types of
integer numbers (of varying sizes),
floating-point
In computing, floating-point arithmetic (FP) is arithmetic that represents real numbers approximately, using an integer with a fixed precision, called the significand, scaled by an integer exponent of a fixed base. For example, 12.345 can b ...
numbers (which approximate
real numbers),
characters and
Booleans. A data type constrains the possible values that an
expression, such as a variable or a function, might take. This data type defines the operations that can be done on the data, the meaning of the data, and the way values of that type can be stored.
Concept
A data type is a collection or grouping of data values. Such a grouping may be defined for many reasons: similarity, convenience, or to focus the attention. It is frequently a matter of good organization
that aids the understanding of complex definitions. Almost all programming languages explicitly include the notion of data type, though the possible data types are often restricted by considerations of simplicity, computability, or regularity. An explicit data type declaration typically allows the compiler to choose an efficient machine representation, but the conceptual organization offered by data types should not be discounted.
Different languages may use different data types or similar types with different semantics. For example, in the
Python programming language,
int
represents an
arbitrary-precision integer which has the traditional numeric operations such as addition, subtraction, and multiplication. However in the
Java programming language, the type
int
represents the set of
32-bit
In computer architecture, 32-bit computing refers to computer systems with a processor, memory, and other major system components that operate on data in 32-bit units. Compared to smaller bit widths, 32-bit computers can perform large calculation ...
integers ranging in value from −2,147,483,648 to 2,147,483,647, with arithmetic operations that wrap on
overflow. In
Rust this 32-bit integer type is denoted
i32
and panics on overflow in debug mode.
Most programming languages also allow the programmer to define additional data types, usually by combining multiple elements of other types and defining the valid operations of the new data type. For example, a programmer might create a new data type named "
complex number" that would include real and imaginary parts, or a color data type represented by three
bytes denoting the amounts each of red, green, and blue, and a string representing the color's name.
Data types are used within
type systems, which offer various ways of defining, implementing, and using them. In a type system, a data type represents a constraint placed upon the interpretation of data, describing representation, interpretation and structure of
values or
objects stored in computer memory. The type system uses data type information to check
correctness of computer programs that access or manipulate the data. A
compiler may use the static type of a value to optimize the storage it needs and the choice of algorithms for operations on the value. In many
C compilers the data type, for example, is represented in 32
bit
The bit is the most basic unit of information in computing and digital communications. The name is a portmanteau of binary digit. The bit represents a logical state with one of two possible values. These values are most commonly represented a ...
s, in accord with the
IEEE specification for single-precision floating point numbers. They will thus use floating-point-specific
microprocessor operations on those values (floating-point addition, multiplication, etc.).
Most
data types in statistics have comparable types in computer programming, and vice versa, as shown in the following table:
Definition
identified five definitions of a "type" that were used—sometimes implicitly—in the literature:
; Syntactic: A type is a purely
syntactic
In linguistics, syntax () is the study of how words and morphemes combine to form larger units such as phrases and sentences. Central concerns of syntax include word order, grammatical relations, hierarchical sentence structure (constituency), ...
label associated with a
variable when it is declared. Although useful for advanced type systems such as
substructural type system
Substructural type systems are a family of type systems analogous to substructural logics where one or more of the structural rules are absent or only allowed under controlled circumstances. Such systems are useful for constraining access to sy ...
s, such definitions provide no intuitive meaning of the types.
; Representation: A type is defined in terms of its composition of more primitive types—often machine types.
; Representation and behaviour: A type is defined as its representation and a set of
operator
Operator may refer to:
Mathematics
* A symbol indicating a mathematical operation
* Logical operator or logical connective in mathematical logic
* Operator (mathematics), mapping that acts on elements of a space to produce elements of another ...
s manipulating these representations.
; Value space: A type is a set of possible values which a variable can possess. Such definitions make it possible to speak about (
disjoint)
unions or
Cartesian product
In mathematics, specifically set theory, the Cartesian product of two sets ''A'' and ''B'', denoted ''A''×''B'', is the set of all ordered pairs where ''a'' is in ''A'' and ''b'' is in ''B''. In terms of set-builder notation, that is
: A\ti ...
s of types.
; Value space and behaviour: A type is a set of values which a variable can possess and a set of
functions that one can apply to these values.
The definition in terms of a representation was often done in imperative languages such as
ALGOL and
Pascal
Pascal, Pascal's or PASCAL may refer to:
People and fictional characters
* Pascal (given name), including a list of people with the name
* Pascal (surname), including a list of people and fictional characters with the name
** Blaise Pascal, Fren ...
, while the definition in terms of a value space and behaviour was used in higher-level languages such as
Simula
Simula is the name of two simulation programming languages, Simula I and Simula 67, developed in the 1960s at the Norwegian Computing Center in Oslo, by Ole-Johan Dahl and Kristen Nygaard. Syntactically, it is an approximate superset of ALGOL 6 ...
and
CLU The term CLU can refer to:
Organizations
* California Lutheran University
* Claremont Lincoln University
* Communion and Liberation – University
* Czech Lacrosse Union
Other uses
* CLU (gene), the gene for clusterin
* CLU (programming l ...
. Types including behavior align more closely with
object-oriented models, whereas a
structured programming
Structured programming is a programming paradigm aimed at improving the clarity, quality, and development time of a computer program by making extensive use of the structured control flow constructs of selection ( if/then/else) and repetition ( ...
model would tend to not include code, and are called
plain old data structures.
Classification
Data types may be categorized according to several factors:
* ''
Primitive data types'' or ''built-in data types'' are types that are built-in to a language implementation. ''User-defined data types'' are non-primitive types. For example, Java's numeric types are primitive, while classes are user-defined.
* A value of an ''atomic type'' is a single data item that cannot be broken into component parts. A value of a ''
composite type'' or ''aggregate type'' is a collection of data items that can be accessed individually. For example, an integer is generally considered atomic, although it consists of a sequence of bits, while an array of integers is certainly composite.
* ''Basic data types'' or ''fundamental data types'' are defined axiomatically from fundamental notions or by enumeration of their elements. ''Generated data types'' or ''derived data types'' are specified, and partly defined, in terms of other data types. All basic types are atomic. For example, integers are a basic type defined in mathematics, while an array of integers is the result of applying an array type generator to the integer type.
The terminology varies - in the literature, primitive, built-in, basic, atomic, and fundamental may be used interchangeably.
Examples
Machine data types
All data in computers based on digital electronics is represented as
bit
The bit is the most basic unit of information in computing and digital communications. The name is a portmanteau of binary digit. The bit represents a logical state with one of two possible values. These values are most commonly represented a ...
s (alternatives 0 and 1) on the lowest level. The smallest addressable unit of data is usually a group of bits called a
byte (usually an
octet, which is 8 bits). The unit processed by
machine code instructions is called a
word (, typically 32 or 64 bits).
Machine data types ''expose'' or make available fine-grained control over hardware, but this can also expose implementation details that make code less portable. Hence machine types are mainly used in
systems programming or
low-level programming languages. In higher-level languages most data types are ''abstracted'' in that they do not have a language-defined machine representation. 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 ...
, for instance, supplies types such as booleans, integers, floating-point numbers, etc., but the precise bit representations of these types are implementation-defined. The only C type with a precise machine representation is the
char
type that represents a byte.
Boolean type
The
Boolean type represents the values
true and
false
False or falsehood may refer to:
* False (logic), the negation of truth in classical logic
*Lie or falsehood, a type of deception in the form of an untruthful statement
* false (Unix), a Unix command
* ''False'' (album), a 1992 album by Gorefest
* ...
. Although only two values are possible, they are more often represented as a word rather as a single bit as it requires more machine instructions to store and retrieve an individual bit. Many programming languages do not have an explicit Boolean type, instead using an integer type and interpreting (for instance) 0 as false and other values as true.
Boolean data refers to the logical structure of how the language is interpreted to the machine language. In this case a Boolean 0 refers to the logic False. True is always a non zero, especially a one which is known as Boolean 1.
Numeric types
Almost all programming languages supply one or more
integer data types. They may either supply a small number of predefined subtypes restricted to certain ranges (such as
short
and
long
and their corresponding
unsigned
variants in C/C++); or allow users to freely define subranges such as 1..12 (e.g.
Pascal
Pascal, Pascal's or PASCAL may refer to:
People and fictional characters
* Pascal (given name), including a list of people with the name
* Pascal (surname), including a list of people and fictional characters with the name
** Blaise Pascal, Fren ...
/
Ada). If a corresponding native type does not exist on the target platform, the compiler will break them down into code using types that do exist. For instance, if a 32-bit integer is requested on a 16 bit platform, the compiler will tacitly treat it as an array of two 16 bit integers.
Floating point data types represent certain fractional values (
rational numbers, mathematically). Although they have predefined limits on both their maximum values and their precision, they are sometimes misleadingly called reals (evocative of mathematical
real numbers
In mathematics, a real number is a number that can be used to measure a ''continuous'' one-dimensional quantity such as a distance, duration or temperature. Here, ''continuous'' means that values can have arbitrarily small variations. Every real ...
). They are typically stored internally in the form (where and are integers), but displayed in familiar
decimal
The decimal numeral system (also called the base-ten positional numeral system and denary or decanary) is the standard system for denoting integer and non-integer numbers. It is the extension to non-integer numbers of the Hindu–Arabic numeral ...
form.
Fixed point data types are convenient for representing monetary values. They are often implemented internally as integers, leading to predefined limits.
For independence from architecture details, a
Bignum
In computer science, arbitrary-precision arithmetic, also called bignum arithmetic, multiple-precision arithmetic, or sometimes infinite-precision arithmetic, indicates that calculations are performed on numbers whose digits of precision are l ...
or
arbitrary precision numeric
type might be supplied. This represents an integer or rational to a precision limited only by the available memory and computational resources on the system. Bignum implementations of arithmetic operations on machine-sized values are significantly slower than the corresponding machine operations.
Enumerations
The
enumerated type has distinct values, which can be compared and assigned, but which do not necessarily have any particular concrete representation in the computer's memory; compilers and interpreters can represent them arbitrarily. For example, the four suits in a deck of playing cards may be four enumerators named ''CLUB'', ''DIAMOND'', ''HEART'', ''SPADE'', belonging to an enumerated type named ''suit''. If a variable ''V'' is declared having ''suit'' as its data type, one can assign any of those four values to it. Some implementations allow programmers to assign integer values to the enumeration values, or even treat them as type-equivalent to integers.
String and text types
String
String or strings may refer to:
*String (structure), a long flexible structure made from threads twisted together, which is used to tie, bind, or hang other objects
Arts, entertainment, and media Films
* ''Strings'' (1991 film), a Canadian anim ...
s are a sequence of
character
Character or Characters may refer to:
Arts, entertainment, and media Literature
* ''Character'' (novel), a 1936 Dutch novel by Ferdinand Bordewijk
* ''Characters'' (Theophrastus), a classical Greek set of character sketches attributed to The ...
s used to store words or
plain text, most often textual
markup languages representing
formatted text. Characters may be a letter of some
alphabet, a digit, a blank space, a punctuation mark, etc. Characters are drawn from a character set such as
ASCII. Character and string types can have different subtypes according to the character encoding. The original 7-bit wide ASCII was found to be limited, and superseded by 8, 16 and 32-bit sets, which can encode a wide variety of non-Latin alphabets (such as
Hebrew and
Chinese) and other symbols. Strings may be of either variable length or fixed length, and some programming languages have both types. They may also be subtyped by their maximum size.
Since most character sets include the
digits, it is possible to have a numeric string, such as
"1234"
. These numeric strings are usually considered distinct from numeric values such as
1234
, although some languages automatically convert between them.
Union types
A union type definition will specify which of a number of permitted subtypes may be stored in its instances, e.g. "float or long integer". In contrast with a
record
A record, recording or records may refer to:
An item or collection of data Computing
* Record (computer science), a data structure
** Record, or row (database), a set of fields in a database related to one entity
** Boot sector or boot record, ...
, which could be defined to contain a float ''and'' an integer, a union may only contain one subtype at a time.
A
tagged union (also called a
variant
Variant may refer to:
In arts and entertainment
* ''Variant'' (magazine), a former British cultural magazine
* Variant cover, an issue of comic books with varying cover art
* ''Variant'' (novel), a novel by Robison Wells
* " The Variant", 2021 e ...
, variant record, discriminated union, or disjoint union) contains an additional field indicating its current type for enhanced type safety.
Algebraic data types
An
algebraic data type (ADT) is a possibly recursive
sum type of
product types. A value of an ADT consists of a constructor tag together with zero or more field values, with the number and type of the field values fixed by the constructor. The set of all possible values of an ADT is the set-theoretic disjoint union (sum), of the sets of all possible values of its variants (product of fields). Values of algebraic types are analyzed with pattern matching, which identifies a value's constructor and extracts the fields it contains.
If there is only one constructor, then the ADT corresponds to a product type similar to a tuple or record. A constructor with no fields corresponds to the empty product (unit type). If all constructors have no fields then the ADT corresponds to an
enumerated type.
One common ADT is the
option type, defined in Haskell as .
Data structures
Some types are very useful for storing and retrieving data and are called
data structure
In computer science, a data structure is a data organization, management, and storage format that is usually chosen for efficient access to data. More precisely, a data structure is a collection of data values, the relationships among them, a ...
s. Common data structures include:
* An
array (also called vector,
list, or sequence) stores a number of elements and provides
random access
Random access (more precisely and more generally called direct access) is the ability to access an arbitrary element of a sequence in equal time or any datum from a population of addressable elements roughly as easily and efficiently as any othe ...
to individual elements. The elements of an array are typically (but not in all contexts) required to be of the same type. Arrays may be fixed-length or expandable. Indices into an array are typically required to be integers (if not, one may stress this relaxation by speaking about an
associative array) from a specific range (if not all indices in that range correspond to elements, it may be a
sparse array).
*
Record
A record, recording or records may refer to:
An item or collection of data Computing
* Record (computer science), a data structure
** Record, or row (database), a set of fields in a database related to one entity
** Boot sector or boot record, ...
(also called tuple or struct) Records are among the simplest
data structure
In computer science, a data structure is a data organization, management, and storage format that is usually chosen for efficient access to data. More precisely, a data structure is a collection of data values, the relationships among them, a ...
s. A record is a value that contains other values, typically in fixed number and sequence and typically indexed by names. The elements of records are usually called ''fields'' or ''members''.
* An
object contains a number of data fields, like a record, and also offers a number of subroutines for accessing or modifying them, called
methods.
* the
singly linked list, which can be used to implement a
queue and is defined in Haskell as the ADT , and
* the
binary tree
In computer science, a binary tree is a k-ary k = 2 tree data structure in which each node has at most two children, which are referred to as the ' and the '. A recursive definition using just set theory notions is that a (non-empty) binary t ...
, which allows fast searching, and can be defined in Haskell as the ADT
Abstract data types
An
abstract data type is a data type that does not specify the concrete representation of the data. Instead, a formal ''specification'' based on the data type's operations is used to describe it. Any ''implementation'' of a specification must fulfill the rules given. For example, a
stack
Stack may refer to:
Places
* Stack Island, an island game reserve in Bass Strait, south-eastern Australia, in Tasmania’s Hunter Island Group
* Blue Stack Mountains, in Co. Donegal, Ireland
People
* Stack (surname) (including a list of people ...
has push/pop operations that follow a Last-In-First-Out rule, and can be concretely implemented using either a list or an array. Another example is a
set which stores values, without any particular
order
Order, ORDER or Orders may refer to:
* Categorization, the process in which ideas and objects are recognized, differentiated, and understood
* Heterarchy, a system of organization wherein the elements have the potential to be ranked a number of d ...
, and no repeated values. Values themselves are not retrieved from sets, rather one tests a value for membership to obtain a boolean "in" or "not in".
Abstract data types are used in formal
semantics and program
verification and, less strictly, in
design. Beyond verification, a specification might immediately be turned into an implementation. The
OBJ family of programming languages for instance bases on this option using
equation
In mathematics, an equation is a formula that expresses the equality of two expressions, by connecting them with the equals sign . The word ''equation'' and its cognates in other languages may have subtly different meanings; for example, in ...
s for specification and
rewriting
In mathematics, computer science, and logic, rewriting covers a wide range of methods of replacing subterms of a well-formed formula, formula with other terms. Such methods may be achieved by rewriting systems (also known as rewrite systems, rewr ...
to run them.
Algebraic specification was an important subject of research in CS around 1980 and almost a synonym for abstract data types at that time. It has a mathematical foundation in
Universal algebra. The specification language can be made more expressive by allowing other formulas than only equations.
A more involved example is the Boom hierarchy of the
binary tree
In computer science, a binary tree is a k-ary k = 2 tree data structure in which each node has at most two children, which are referred to as the ' and the '. A recursive definition using just set theory notions is that a (non-empty) binary t ...
,
list,
bag and
set abstract data types. All these data types can be declared by three operations: ''null'', which constructs the empty container, ''single'', which constructs a container from a single element and ''append'', which combines two containers of the same type. The complete specification for the four data types can then be given by successively adding the following rules over these operations:
Access to the data can be specified by pattern-matching over the three operations, e.g. a ''member'' function for these containers by:
Care must be taken to ensure that the function is invariant under the relevant rules for the data type. Within each of the equivalence classes implied by the choosen subset of equations, it has to yield the same result for all of its members.
Pointers and references
The main non-composite, derived type is the
pointer
Pointer may refer to:
Places
* Pointer, Kentucky
* Pointers, New Jersey
* Pointers Airport, Wasco County, Oregon, United States
* The Pointers, a pair of rocks off Antarctica
People with the name
* Pointer (surname), a surname (including a list ...
, a data type whose value refers directly to (or "points to") another value stored elsewhere in the
computer memory using its
address. It is a primitive kind of
reference. (In everyday terms, a page number in a book could be considered a piece of data that refers to another one). Pointers are often stored in a format similar to an integer; however, attempting to dereference or "look up" a pointer whose value was never a valid memory address would cause a program to crash. To ameliorate this potential problem, pointers are considered a separate type to the type of data they point to, even if the underlying representation is the same.
Function types
Functional programming languages treat functions as a distinct datatype and allow values of this type to be stored in variables and passed to functions. Some multi-paradigm languages such as
JavaScript also have mechanisms for treating functions as data. Most contemporary
type systems
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 ...
go beyond JavaScript's simple type "function object" and have a family of function types differentiated by argument and return types, such as the type
Int -> Bool
denoting functions taking an integer and returning a boolean. In C, a function is not a first-class data type but
function pointers can be manipulated by the program. Java and C++ originally did not have function values but have added them in C++11 and Java 8.
In mathematical logic,
first-order logic does not allow the application of
quantifiers on function or predicate names, although
second-order logic does.
Type constructors
A type constructor builds new types from old ones, and can be thought of as an operator taking zero or more types as arguments and producing a type. Product types, function types, power types and list types can be made into type constructors.
Quantified types
Universally-quantified and existentially-quantified types are based on
predicate logic. Universal quantification is written as
or
forall x. f x
and is the intersection over all types
x
of the body
f x
, i.e. the value is of type
f x
for every
x
. Existential quantification written as
or
exists x. f x
and is the union over all types
x
of the body
f x
, i.e. the value is of type
f x
for some
x
.
In Haskell, universal quantification is commonly used, but existential types must be encoded by transforming
exists a. f a
to
forall r. (forall a. f a -> r) -> r
or a similar type.
Refinement types
A refinement type is a type endowed with a predicate which is assumed to hold for any element of the refined type. For instance, the type of natural numbers greater than 5 may be written as
Dependent types
A dependent type is a type whose definition depends on a value. Two common examples of dependent types are dependent functions and dependent pairs. The return type of a dependent function may depend on the value (not just type) of one of its arguments. A dependent pair may have a second value of which the type depends on the first value.
Meta types
Some programming languages represent the type information as data, enabling
type introspection and
reflection. In contrast,
higher order type systems
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 ...
, while allowing types to be constructed from other types and passed to functions as values, typically avoid basing
computational decisions on them.
Convenience types
For convenience, high-level languages and databases may supply ready-made "real world" data types, for instance times, dates, and monetary values (currency). These may be built-in to the language or implemented as composite types in a library.
See also
*
C data types
*
Data dictionary
*
Functional programming
*
Kind
*
Type (model theory)
*
Type theory for the mathematical models of types
*
Type system for different choices in programming language typing
*
Type conversion
*
ISO/IEC 11404, General Purpose Datatypes
References
Further reading
*
*
*
External links
*
{{DEFAULTSORT:Data Type
Programming language concepts