U+2017‗DOUBLE LOW LINE U+2381⎁CONTINUOUS UNDERLINE SYMBOL U+2382⎂DISCONTINUOUS UNDERLINE SYMBOL U+FE33︳PRESENTATION FORM FOR VERTICAL LOW LINE
An underscore or underline is a line drawn under a segment of text. In proofreading, underscoring is a convention that says "set this text in italic type", traditionally used on manuscript or typescript as an instruction to the printer. Its use to add emphasis in modern finished documents is generally avoided.[1]
The (freestanding) underscore character, _, also called a low line, or low dash, originally appeared on the typewriter so that underscores could be typed. To produce an underscored word, the word was typed, the typewriter carriage was moved back to the beginning of the word, and the word was overtyped with the underscore character.
In modern usage, underscoring is achieved with a markup language, with the Unicode combining low line or as a standard facility of word processing software. The free-standing underscore character is used to indicate word boundaries in situations where spaces are not allowed, such as in computer filenames, email addresses, and in Internet URLs, for example Mr_John_Smith. It is also used as a proofreader's mark, to indicate that text should be underscored or italicised when typeset, for instance _thus_ is to be rendered as thus or thus.
The combining diacritic, ◌̱ (macron below), is similar to the combining low line but is shorter. The difference between "macron below" and "low line" is that the latter results in an unbroken underline when it is run together: compare a̱ḇc̱ and a̲b̲c̲ (only the latter should look like abc).[2][a]
Modern use
In a manuscript (or typescript) to be typeset, various forms of underlining (see below) were therefore conventionally used to indicate that text should be set in special type such as italics, part of a procedure known as markup. In printed documents underlining is generally avoided, with italics or small caps often used instead, or (especially in headings) using capitalization, bold type or greater body height (font size).[1] Underlining may still be seen in display work.[3]
A series of underscores (like __________ ) may be used to reserve a blank space in text that is later to be filled in by hand, such as on a paper form. It is also sometimes used to create a horizontal line; other symbols with similar glyphs, such as hyphens and dashes, are also used for this purpose.
The underscore is also used in modern editions of Spanish vocal sheet music to indicate elision, instead of the breve below (U+032E◌̮COMBINING BREVE BELOW), which is less convenient to input on a computer.
Mathematics
In mathematical notations, underscores are sometimes used in the following contexts:
vectors. Underscores are sometimes used instead of bold face or a variable with an overarrow. E.g.: [5]
complex numbers. Similar to vectors, underscored variable names can indicate a complex-valued variable, especially if the real-valued variable name is reused to indicate the complex variable. For instance, in optics, is often used for a medium's index of refraction. When the refractive index has a wavelength-dependent extinction coefficient , the combined complex index of refraction is sometimes notated
minimum bound. Example: where is the lower bound of and is the upper bound.[6]
Usage in computing
In web browsers, default settings typically distinguish hyperlinks by underlining them (and usually changing their color), but both users and websites can change the settings to make some or all hyperlinks appear differently (or even without distinction from normal text).[1]
History
As early output devices (Teleprinters, CRTs and line printers) could not produce more than one character at a location, it was not possible to underscore text, so early encodings such as ITA2 and the first versions of ASCII had no underscore. IBM's EBCDIC character-coding system, introduced in 1964, added the underscore, which IBM referred to as the "break character". IBM's report on NPL (the early name of what is now called PL/I) leaves the character set undefined, but specifically mentions the break character, and gives RATE_OF_PAY as an example identifier.[7] By 1967 the underscore had spread to ASCII,[8] replacing the similarly shaped left-arrow character, ← (see also: PIP). C, developed at Bell Labs in the early 1970s, allowed the underscore in identifiers.[9]
Underscore predates the existence of lower-case letters in many systems, so often it had to be used to make multi-word identifiers, since camelCase (see below) was not available.
Programming conventions
Underscores inserted between letters are very common to make a "multi-word" identifier in languages that cannot handle spaces in identifiers. This convention is known as "snake case" (the other popular method is called camelCase, where capital letters are used to show where the words start).
An underscore as the first character in an ID is often used to indicate an internal implementation that is not considered part of the API and should not be called by code outside that implementation. In Dart, all private properties of classes must start with an underscore; this usage is also common in other languages such as C++ even though those provide keywords to indicate that members are private. It is extensively used to hide variables and functions used for implementations in header files. In fact, the use of a single underscore for this became so common that C compilers had to standardize on a double leading underscore (for instance __DATE__) for actual built-in variables to avoid conflicts with the ones in header files. PHP "reserves all function names starting with __ as magical."[10]
Python uses names that both start and end with double underscores (so called "dunder methods", as in double underscore) for magic members used for purposes such as operator overloading and reflection, and names starting but not ending with a double underscore to denote private member variables of classes which should be mangled in a manner which prevents them from colliding with members of derived classes unless the classes have the same name (__bar in class Foo will be mangled to _Foo__bar). By convention, members starting with a single underscore are considered private or protected, although this behavior only has inherent effect for modules, where import * statements by default import all names that do not start with an underscore, unless an export list is explicitly defined by the module.
A variable named with just an underscore often has special meaning. $_ or _ is the previous command or result in many interactive shells, such as those of Python, Ruby, and Perl. In Perl, @_ is a special array variable that holds the arguments to a function. In Clojure, it indicates an argument whose value will be ignored.[11]
The ASCII underscore character can be inserted with the entities_ or _ (or _ or _).
HTML has a presentational element<u> that was originally used to underline text; this usage was deprecated in HTML4 in favor of the CSS style {text-decoration: underline}.[12] In HTML5, the tag reappeared but its meaning was changed significantly: it now "represents a span of inline text which should be rendered in a way that indicates that it has a non-textual annotation".[12] This facility is intended for example to provide a red wavy line (or wiggly line) underline to flag spelling errors at input time but which are not to be embedded in any stored file (unlike an emphasis mark, which would be). Other styles are also available: doubled, dotted, and dashed.[13]
The elements may also exist in other markup languages, such as MediaWiki. The Text Encoding Initiative (TEI) provides an extensive selection of related elements for marking editorial activity (insertion, deletion, correction, addition, etc.).
Unicode
Unicode has a free-standing underscore _ at U+005F, inherited from ASCII, which is a legacy of the typewriter practice of underlining using backspace and overtype. Modern practice uses the combining diacriticU+0332◌̲COMBINING LOW LINE that results in an underline when run together: u̲n̲d̲e̲r̲l̲i̲n̲e̲. Unicode also has U+0333◌̳COMBINING DOUBLE LOW LINE. In addition, there are single line and double line versions of the combining macron below, a diacritic that applies to single letters only.[2]
In plain-text applications, including plain-text e-mails where emphasis markup is not possible, the desired emphasis is often indicated by surrounding words with underscore characters. For example, "You must use _emulsion_ paint on the ceiling".
Some applications will automatically add emphasis to text manually bracketed by underscores, either by underlining or by italicizing it (e.g. _string_ may render as either string or string).
As a marker for incorrectness
Underline (typically red or wavy or both) is often used by spell checkers (and grammar checkers) to denote misspelled or otherwise incorrect text.
Depending on local conventions, the following kinds of underlines may be used inline on manuscripts to indicate the special typefaces to be used:[14][15]
single dashed underline for stet, 'let it stand', proof-reading mark cancelled.
single straight underline for italic type
single wavy underline for bold type
double straight underline for SMALL CAPS
double underline of one straight line and one wavy line for bold italic
triple underline for FULL CAPITAL LETTERS (used among small caps or to change text already typed as lower case).
Underlines in Chinese
In Chinese, the underline is a little-used punctuation mark for proper names (simplified Chinese: 专名号; traditional Chinese: 專名號; pinyin: zhuānmínghào; literally "proper name mark", used for personal and geographic names). Its meaning is somewhat akin to capitalization in English and should never be used for emphasis even if the influence of English computing makes the latter sometimes occur. A wavy underline (simplified Chinese: 书名号; traditional Chinese: 書名號; pinyin: shūmínghào; literally, "book title mark") serves a similar function, but marks names of literary works instead of proper names.[16]
In the case of two or more adjacent proper names, each individual proper name is separately underlined so there should be a slight gap between the underlining of each proper name.
^This text describes how 'low line' should be implemented and in most cases it usually is (for example, Windows+Firefox, ChromeOS+Chrome). However, it has been observed that the Chrome Browser on at least some releases of Android fails to do so correctly and the line is broken. This is an implementation error.
References
^ abcdButterick, Matthew (2013). "Underlining: absolutely not". practicaltypography.com. Archived from the original on 23 November 2020. Retrieved 5 August 2015. Don't underline. Ever. It's ugly and it makes text harder to read. Underlining is another dreary typewriter habit... a workaround for shortcomings in typewriter technology.
^ ab"6.2 General Punctuation"(PDF). The Unicode Standard. Version 11.0.0. Mountain View, CA: The Unicode Consortium. 2018. p. 273. ISBN978-1-936213-19-1. Archived(PDF) from the original on 2018-12-21. Retrieved 2018-12-12. Spacing Overscores and Underscores. U+203E OVERLINE is the above-the-line counterpart to U+005F low line. It is a spacing character, not to be confused with U+0305 COMBINING OVERLINE. As with all overscores and underscores, a sequence of these characters should connect in an unbroken line. The overscoring characters also must be distinguished from U+0304 COMBINING MACRON, which does not connect horizontally in this way.
^Strizver, Ilene. "Underlining Text". fonts.com. Archived from the original on 21 March 2023. Retrieved 15 June 2023.
^Writers' & Artists' Yearbook 2020. Bloomsbury. 5 September 2019. ISBN9781472947512.
^Tung, Bobby; Chen, Yijun; Eric, Liu; Hui Jing, Chen; Zhengyu, Qian; Fuqiao, Xue; Richard, Ishida. "Requirements for Chinese Text Layout". World Wide Web Consortium (W3C). Archived from the original on 19 April 2016. Retrieved 22 April 2023.