Basic types

D provides a number of basic types which always have the same size regardless of the platform - the only exception is the real type which provides the highest possible floating point precision. There is no difference between the size of an integer regardless of whether the application is compiled for 32-bit or 64-bit systems.

typesize
bool, byte, ubyte, char8-bit
short, ushort, wchar16-bit
int, uint, dchar32-bit
long, ulong64-bit

Floating point types:

typesize
float32-bit
double64-bit
real>= 64-bit (generally 64-bit, but 80-bit on Intel x86 32-bit)

The prefix u denotes unsigned types. char translates to UTF-8 characters, wchar is used in UTF-16 strings and dchar in UTF-32 strings.

A conversion between variables of different types is only allowed by the compiler if no precision is lost. However, a conversion between floating point types (e.g double to float) is allowed.

A conversion to another type may be forced by using the cast(TYPE) myVar expression. It needs to be used with great care though, as the cast expression is allowed to break the type system.

The special keyword auto creates a variable and infers its type from the right hand side of the expression. auto myVar = 7 will deduce the type int for myVar. Note that the type is still set at compile-time and can't be changed - just like with any other variable with an explicitly given type.

Type properties

All data types have a property .init to which they are initialized. For all integers this is 0 and for floating points it is nan (not a number).

Integral and floating point types have a .max property for the highest value they can represent. Integral types also have a .min property for the lowest value they can represent, whereas floating point types have a .min_normal property which is defined to the smallest representable normalized value that's not 0.

Floating point types also have properties .nan (NaN-value), .infinity (infinity value), .dig (number of decimal digits of precisions), .mant_dig (number of bits in mantissa) and more.

Every type also has a .stringof property which yields its name as a string.

Indexes in D

In D, indexes usually have the alias type size_t, as it is a type that is large enough to represent an offset into all addressable memory - this is uint for 32-bit and ulong for 64-bit architectures.

Assert expression

assert is an expression which verifies conditions in debug mode and aborts with an AssertionError if it fails. assert(0) is thus used to mark unreachable code.

In-depth

Basic references

Advanced references

rdmd playground.d