Primitive data type explained

In computer science, primitive data types are a set of basic data types from which all other data types are constructed.[1] Specifically it often refers to the limited set of data representations in use by a particular processor, which all compiled programs must use. Most processors support a similar set of primitive data types, although the specific representations vary.[2] More generally, primitive data types may refer to the standard data types built into a programming language (built-in types).[3] [4] Data types which are not primitive are referred to as derived or composite.[3]

Primitive types are almost always value types, but composite types may also be value types.[5]

Common primitive data types

The most common primitive types are those used and supported by computer hardware, such as integers of various sizes, floating-point numbers, and Boolean logical values. Operations on such types are usually quite efficient. Primitive data types which are native to the processor have a one-to-one correspondence with objects in the computer's memory, and operations on these types are often the fastest possible in most cases.[6] Integer addition, for example, can be performed as a single machine instruction, and some offer specific instructions to process sequences of characters with a single instruction.[7] But the choice of primitive data type may affect performance, for example it is faster using SIMD operations and data types to operate on an array of floats.

Integer numbers

See main article: Integer (computer science). An integer data type represents some range of mathematical integers. Integers may be either signed (allowing negative values) or unsigned (non-negative integers only). Common ranges are:

Size (bytes)Size (bits)NamesSigned range (two's complement representation)Unsigned range
1 byte8 bitsByte, octet, minimum size of char in C99(see limits.h CHAR_BIT)−128 to +1270 to 255
2 bytes16 bitsx86 word, minimum size of short and int in C−32,768 to +32,7670 to 65,535
4 bytes32 bitsx86 double word, minimum size of long in C, actual size of int for most modern C compilers,[8] pointer for IA-32-compatible processors−2,147,483,648 to +2,147,483,6470 to 4,294,967,295
8 bytes64 bitsx86 quadruple word, minimum size of long long in C, actual size of long for most modern C compilers, pointer for x86-64-compatible processors−9,223,372,036,854,775,808 to +9,223,372,036,854,775,8070 to 18,446,744,073,709,551,615

Floating-point numbers

See main article: Floating-point arithmetic. A floating-point number represents a limited-precision rational number that may have a fractional part. These numbers are stored internally in a format equivalent to scientific notation, typically in binary but sometimes in decimal. Because floating-point numbers have limited precision, only a subset of real or rational numbers are exactly representable; other numbers can be represented only approximately. Many languages have both a single precision (often called float) and a double precision type (often called double).

Booleans

See main article: Boolean data type. A Boolean type, typically denoted bool or boolean, is typically a logical type that can have either the value true or the value false. Although only one bit is necessary to accommodate the value set true and false, programming languages typically implement Boolean types as one or more bytes.

Many languages (e.g. Java, Pascal and Ada) implement Booleans adhering to the concept of Boolean as a distinct logical type. Some languages, though, may implicitly convert Booleans to numeric types at times to give extended semantics to Booleans and Boolean expressions or to achieve backwards compatibility with earlier versions of the language. For example, early versions of the C programming language that followed ANSI C and its former standards did not have a dedicated Boolean type. Instead, numeric values of zero are interpreted as false, and any other value is interpreted as true.[9] The newer C99 added a distinct Boolean type _Bool (the more intuitive name bool as well as the macros true and false can be included with stdbool.h),[10] and C++ supports bool as a built-in type and true and false as reserved words.[11]

Specific languages

Java

The Java virtual machine's set of primitive data types consists of:[12]

C basic types

The set of basic C data types is similar to Java's. Minimally, there are four types, char, int, float, and double, but the qualifiers short, long, signed, and unsigned mean that C contains numerous target-dependent integer and floating-point primitive types.[15] C99 extended this set by adding the Boolean type _Bool and allowing the modifier long to be used twice in combination with int (e.g. long long int).[16]

XML Schema

The XML Schema Definition language provides a set of 19 primitive data types:[17]

JavaScript

In JavaScript, there are 7 primitive data types: string, number, bigint, boolean, symbol, undefined, and null.[19] Their values are considered immutable. These are not objects and have no methods or properties; however, all primitives except undefined and null have object wrappers.[20]

Visual Basic .NET

In Visual Basic .NET, the primitive data types consist of 4 integral types, 2 floating-point types, a 16-byte decimal type, a Boolean type, a date/time type, a Unicode character type, and a Unicode string type.[21]

Rust

Rust has primitive unsigned and signed fixed width integers in the format u or i respectively followed by any bit width that is a power of two between 8 and 128 giving the types u8, u16, u32, u64, u128, i8, i16, i32, i64 and i128.[22] Also available are the types usize and isize which are unsigned and signed integers that are the same bit width as a reference with the usize type being used for indices into arrays and indexable collection types.

Rust also has:

Built-in types

Built-in types are distinguished from others by having specific support in the compiler or runtime, to the extent that it would not be possible to simply define them in a header file or standard library module.[23] Besides integers, floating-point numbers, and Booleans, other built-in types include:

Characters and strings

A character type is a type that can represent all Unicode characters, hence must be at least 21 bits wide. Some languages such as Julia include a true 32-bit Unicode character type as primitive.[24] Other languages such as JavaScript, Python, Ruby, and many dialects of BASIC do not have a primitive character type but instead add strings as a primitive data type, typically using the UTF-8 encoding. Strings with a length of one are normally used to represent single characters.

Some languages have character types that are too small to represent all Unicode characters. These are more properly categorized as integer types that have been given a misleading name. For example C includes a char type, but it is defined to be the smallest addressable unit of memory, which several standards (such as POSIX) require to be 8 bits. Recent versions of these standards refer to char as a numeric type. char is also used for a 16-bit integer type in Java, but again this is not a Unicode character type.[25]

The term string also does not always refer to a sequence of Unicode characters, instead referring to a sequence of bytes. For example, x86-64 has string instructions to move, set, search, or compare a sequence of items, where an item could be 1, 2, 4, or 8 bytes long.[26]

See also

Notes and References

  1. Book: Stone . R. G. . Program Construction . Cooke . D. J. . 5 February 1987 . Cambridge University Press . 978-0-521-31883-9 . 18 . en-US.
  2. Book: Wikander . Jan . Svensson . Bertil . Real-Time Systems in Mechatronic Applications . 31 May 1998 . Springer Science & Business Media . 978-0-7923-8159-4 . 101 . en.
  3. Book: Khurana . Rohit . Data and File Structure (For GTU), 2nd Edition . Vikas Publishing House . 978-93-259-6005-3 . 2 . en.
  4. Book: Chun . Wesley . Core Python Programming . 2001 . Prentice Hall Professional . 978-0-13-026036-9 . 77 . en.
  5. Book: Olsen . Geir . Allison . Damon . Speer . James . Visual Basic .NET Class Design Handbook: Coding Effective Classes . 1 January 2008 . Apress . 978-1-4302-0780-1 . 80 . en.
  6. Web site: Fog . Agner . Optimizing software in C++ . 28 January 2022 . 29 . Integer operations are fast in most cases, [...].
  7. Web site: Single Instruction Single Data - an overview | ScienceDirect Topics.
  8. Web site: Calling conventions for different C++ compilers and operating systems: Chapter 3, Data Representation . 2010-02-16 . 2010-08-30 . Fog . Agner.
  9. Book: Brian W . Kernighan . Brian Kernighan . Dennis M . Ritchie . Dennis Ritchie . 41 . . 1st . . 1978 . . 0-13-110163-3.
  10. Web site: Boolean type support library. October 15, 2020. devdocs.io.
  11. Web site: Bool data type in C++. October 15, 2020. GeeksforGeeks. 5 June 2017.
  12. Book: Lindholm . Tim . Yellin . Frank . Bracha . Gilad . Buckley . Alex . The Java® Virtual Machine Specification . 13 February 2015 . Chapter 2. The Structure of the Java Virtual Machine.
  13. Book: Cowell . John . Essential Java Fast: How to write object oriented software for the Internet . 18 February 1997 . Springer Science & Business Media . 978-3-540-76052-8 . 27 . en.
  14. Book: Rakshit . Sandip . Panigrahi . Goutam . A Hand Book of Objected Oriented Programming With Java . December 1995 . S. Chand Publishing . 978-81-219-3001-7 . 11 . en.
  15. Book: Kernighan . Brian W.. Ritchie. Dennis M. . The C programming language. 2.2 Data Types and Sizes . 1988 . Englewood Cliffs, N.J. . 0131103709 . 36 . Second.
  16. Book: ISO/IEC 9899:1999 specification, TC3 . p. 255, § 6.2.5 Types.
  17. Web site: Biron . Paul V. . Malhotra . Ashok . XML Schema Part 2: Datatypes . www.w3.org . 29 January 2022 . Second.
  18. News: Phillips . Lee Anne . Declaring a NOTATION Understanding XML Document Type Definitions . 29 January 2022 . www.informit.com . 18 January 2002.
  19. Web site: Primitive - MDN Web Docs Glossary: Definitions of Web-related terms . 8 June 2023 . MDN.
  20. Web site: JavaScript data types and data structures . MDN . 9 July 2024.
  21. Web site: Types in Visual Basic . Microsoft Docs . 18 May 2022 . en-us . 18 September 2021.
  22. Web site: Data Types - The Rust Programming Language . 2023-10-17 . doc.rust-lang.org.
  23. Web site: Built-in types (C++) . learn.microsoft.com . en-us . 17 August 2021.
  24. Web site: Strings · The Julia Language . docs.julialang.org . 29 January 2022.
  25. Web site: Mansoor . Umer . The char Type in Java is Broken . CodeAhoy . 8 May 2016 . 10 February 2020 . 3.
  26. Web site: I/O and string instructions. 29 January 2022.