Nullable type

Feature of some programming languages


title: "Nullable type" type: doc version: 1 created: 2026-02-28 author: "Wikipedia contributors" status: active scope: public tags: ["type-theory"] description: "Feature of some programming languages" topic_path: "technology/computing" source: "https://en.wikipedia.org/wiki/Nullable_type" license: "CC BY-SA 4.0" wikipedia_page_id: 0 wikipedia_revision_id: 0

::summary Feature of some programming languages ::

Nullable types are a feature of some programming languages which allow a value to be set to the special value NULL instead of the usual possible values of the data type. In statically typed languages, a nullable type is an option type, while in dynamically typed languages (where values have types, but variables do not), equivalent behavior is provided by having a single null value.

NULL is frequently used to represent a missing value or invalid value, such as from a function that failed to return or a missing field in a database, as in NULL in SQL. In other words, NULL is undefined.

Primitive types such as integers and Booleans cannot generally be null, but the corresponding nullable types (nullable integer and nullable Boolean, respectively) can also assume the NULL value. This can be represented in ternary logic as FALSE, NULL, TRUE as in three-valued logic.

Example

An integer variable may represent integers, but 0 (zero) is a special case because 0 in many programming languages can mean "false". Also, this does not provide any notion of saying that the variable is empty, a need that arises in many circumstances. This need can be achieved with a nullable type. In programming languages like C# 2.0, a nullable integer, for example, can be declared by a question mark (int? x). In programming languages like C# 1.0, nullable types can be defined by an external library as new types (e.g. NullableInteger, NullableBoolean).

A Boolean variable makes the effect more clear. Its values can be either "true" or "false", while a nullable Boolean may also contain a representation for "undecided". However, the interpretation or treatment of a logical operation involving such a variable depends on the language.

The following is an example of T? (or explicitly System.Nullable) in C#. ::code[lang=csharp] using System;

public class Example { static void Main(string[] args) { // Using shorthand int? a = 10; double? b = null;

    // Using explicit Nullable<T>
    Nullable<int> c = 20;
    Nullable<double> d = 5.5;

    // Checking if the nullable variables have values
    Console.WriteLine(a.HasValue); // True
    Console.WriteLine(b.HasValue); // False
    Console.WriteLine(c.HasValue); // True
    Console.WriteLine(d.HasValue); // True

    // Accessing the values
    if (a.HasValue)
    {
        Console.WriteLine(a.Value); // 10
    }

    if (b.HasValue)
    {
        Console.WriteLine(b.Value); // (won't be executed because b is null)
    }
}

}

::

Compared with null pointers

In contrast, object pointers can be set to NULL by default in most common languages, meaning that the pointer or reference points to nowhere, that no object is assigned (the variable does not point to any object). Nullable references were invented by C. A. R. Hoare in 1965 as part of the Algol W language. Hoare later described his invention as a "billion-dollar mistake".{{cite web |url=http://www.infoq.com/presentations/Null-References-The-Billion-Dollar-Mistake-Tony-Hoare |title=Null References: The Billion Dollar Mistake |location=QCon London |year=2009 |author=Tony Hoare}} This is because object pointers that can be NULL require the user to check the pointer before using it and require specific code to handle the case when the object pointer is NULL.

Java has classes that correspond to scalar values, such as Integer, Boolean, and Float. Combined with autoboxing (automatic usage-driven conversion between object and value), this effectively allows nullable variables for scalar values.

Compared with option types

Nullable type implementations usually adhere to the null object pattern.

There is a more general and formal concept that extend the nullable type concept: it comes from option types, which enforce explicit handling of the exceptional case.

Language support

The following programming languages support nullable types.

Statically typed languages with native null support include:

Statically typed languages with library null support include:

Dynamically-typed languages with null include:

  • JavaScript has a null and undefined values.
  • Julia has the nothing value (which is of type Nothing) and the Union{T, Nothing} type idiom.
  • Perl scalar variables default to undef and can be set to undef.
  • PHP with NULL type and is_null() method, native nullable type in version 7.1
  • Python has the None value.
  • Ruby has the nil value and NilClass type.

References

References

  1. "Nullable Types (C#)". Msdn.microsoft.com.
  2. Skeet, Jon. (23 March 2019). "C# in Depth". Manning.
  3. "(luKa) Developer Zone - NullableTypes". Nullabletypes.sourceforge.net.
  4. "NullableTypes". Nullabletypes.sourceforge.net.
  5. (2012-12-13). "Programming with Objective-C: Working with Objects". Developer.apple.com.
  6. "Optional Type - Ballerina Programming Language".
  7. BillWagner. "Nullable value types - C# reference".
  8. "Sound null safety".
  9. "Null Safety - Kotlin Programming Language".
  10. KathleenDollard. "Nullable Value Types - Visual Basic".
  11. "Types · the Julia Language".
  12. "PHP: RFC:nullable_types".
  13. "Built-in Constants — Python 3.9.5 documentation".

::callout[type=info title="Wikipedia Source"] This article was imported from Wikipedia and is available under the Creative Commons Attribution-ShareAlike 4.0 License. Content has been adapted to SurfDoc format. Original contributors can be found on the article history page. ::

type-theory