Mark: | _ ◌̲ |
Unicode: | |
See Also: | |
Variant1: | _ |
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 . It is also used as a proofreader's mark, to indicate that text should be underscored or italicised when typeset, for instance is to be rendered as or thus.
See also: Macron below and Numero sign.
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 and (only the latter should look like
abc).[2]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). 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.
In German, Slovene and some other Slavic languages, the underscore has recently gained prominence as the punctuation to form gender-neutral suffixes in gendered nouns and other parts of the speech.[4]
The underscore is also used in modern editions of Spanish vocal sheet music to indicate elision, instead of the breve below, which is less convenient to input on a computer.
In mathematical notations, underscores are sometimes used in the following contexts:
\underline{v}=v=\left[v1 v
T. | |
2\right] |
n
\kappa
\underline{n}=n+i\kappa.
\underline{x}<x<\overline{x},
\underline{x}
x,
\overline{x}
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]
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 as an example identifier.[6] By 1967 the underscore had spread to ASCII,[7] replacing the similarly shaped left-arrow character, (see also: PIP). C, developed at Bell Labs in the early 1970s, allowed the underscore in identifiers.[8]
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.
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."[9]
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 (in class will be mangled to). By convention, members starting with a single underscore are considered private or protected, although this behavior only has inherent effect for modules, where 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.[10]
In some languages with pattern matching, such as Prolog, Standard ML, Scala, OCaml, Haskell, Erlang, and the Wolfram Language, the pattern _
matches any value, but does not perform binding.
HTML has a presentational element <nowiki><u></nowiki>
that was originally used to underline text; this usage was deprecated in HTML4 in favor of the CSS style {text-decoration: underline}
.[11]
The elements may also exist in other markup language
]s, 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 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 diacritic that results in an underline when run together: u̲n̲d̲e̲r̲l̲i̲n̲e̲. Unicode also has . In addition, there are single line and double line versions of the combining macron below, a diacritic that applies to single letters only.
Effect | Using combining diacritic | Using html span style | Using macron below |
---|---|---|---|
single underline | a̲b̲c̲d̲e̲f̲g̲h̲i̲j̲k̲l̲m̲n̲o̲p̲q̲r̲s̲t̲u̲v̲w̲x̲y̲z̲0̲1̲2̲3̲4̲5̲6̲7̲8̲9̲ | a̱ḇc̱ḏe̱ | |
double underline | a̲̲b̲̲c̲̲d̲̲e̲̲f̲̲g̲̲h̲̲i̲̲j̲̲k̲̲l̲̲m̲̲n̲̲o̲̲p̲̲q̲̲r̲̲s̲̲t̲̲u̲̲v̲̲w̲̲x̲̲y̲̲z̲̲0̲̲1̲̲2̲̲3̲̲4̲̲5̲̲6̲̲7̲̲8̲̲9̲̲ | ||
single underline | A̲B̲C̲D̲E̲F̲G̲H̲I̲J̲K̲L̲M̲N̲O̲P̲Q̲R̲S̲T̲U̲V̲W̲X̲Y̲Z̲ | A̱ḆC̱ḎE̱ | |
double underline | A̲̲B̲̲C̲̲D̲̲E̲̲F̲̲G̲̲H̲̲I̲̲J̲̲K̲̲L̲̲M̲̲N̲̲O̲̲P̲̲Q̲̲R̲̲S̲̲T̲̲U̲̲V̲̲W̲̲X̲̲Y̲̲Z̲̲ |
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. may render as either or string).
Underline (typically red or wavy or both) is often used by spell checkers (and grammar checkers) to denote misspelled or otherwise incorrect text.
See main article: List of proofreader's marks. Depending on local conventions, the following kinds of underlines may be used inline on manuscripts to indicate the special typefaces to be used:[12] [13]
In Chinese, the underline is a little-used punctuation mark for proper names (; 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 (; pinyin: shūmínghào; literally, "book title mark") serves a similar function, but marks names of literary works instead of proper names.[14]
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.