Null character
The null character is a control character with the value zero. Many character sets include a code point for a null character including Unicode, ASCII, Baudot, ITA2 codes, the C0 control code, and EBCDIC. In modern character sets, the null character has a code point value of zero which is generally translated to a single code unit with a zero value. For instance, in UTF-8, it is a single, zero byte.
Originally, its meaning was like NOP when sent to a printer or a terminal, it had no effect. When electromechanical teleprinters were used as computer output devices, one or more null characters were sent at the end of each printed line to allow time for the mechanism to return to the first printing position on the next line. On punched tape, the character is represented with no holes at all, so a new unpunched tape is initially filled with null characters, and often text could be inserted at a reserved space of null characters by punching the new characters into the tape over the nulls.
A null-terminated string is a commonly used data structure in the C programming language, its many derivative languages and other programming contexts that uses a null character to indicate the end of a string. This design allows a string to be any length at the cost of only one extra character of memory. The common competing design for a string stores the length of the string as an integer data type, but this limits the size of the string to the range of the integer.
For byte storage, the null character can be called a null byte.
Representation
Since the null character is not a printable character, representing it requires special notation in source code.In a string literal, the null character is often represented as the escape sequence
\0. Similar notation is often used for a character literal although that is often equivalent to the numeric literal for zero. In many languages, this is not a separate escape sequence, but an octal escape sequence with a single octal digit 0; as a consequence, \0 must not be followed by any of the digits 0 through 7 because in that case it will be interpreted as the start of a longer octal escape sequence. Other escape sequences that are found in use in various languages are \000, \x00, \z, or \u0000. A null character can be placed in a URL with the percent code
%00.The ability to represent a null character does not always mean the resulting string will be correctly interpreted, as many programs will consider the null to be the end of the string. Thus, the ability to type it creates a vulnerability known as null byte injection and can lead to security exploits.
In software documentation, the null character is often represented with the text NUL. In Unicode, there is a character for this:.
In caret notation the null character is
^@. On some keyboards, one can enter a null character by holding down and pressing .