博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
编程基础-字符篇-(1)
阅读量:6685 次
发布时间:2019-06-25

本文共 6621 字,大约阅读时间需要 22 分钟。

Byte order mark

 

Byte order mark

From Wikipedia, the free encyclopedia
Jump to: ,

The byte order mark (BOM) is a character used to signal the (byte order) of a text file or stream. Its code point is U+FEFF. BOM use is optional, and, if used, should appear at the start of the text stream. Beyond its specific use as a byte-order indicator, the BOM character may also indicate which of the several Unicode representations the text is encoded in.

Because Unicode can be encoded as 16-bit or 32-bit integers, a computer receiving these encodings from arbitrary sources needs to know which byte order the integers are encoded in. The BOM gives the producer of the text a way to describe the text stream's endianness to the consumer of the text without requiring some contract or metadata outside of the text stream itself. Once the receiving computer has consumed the text stream, it presumably processes the characters in its own native byte order and no longer needs the BOM. Hence the need for a BOM arises in the context of text interchange, rather than in normal text processing within a closed environment.

Contents

[]

[] Usage

If the BOM character appears in the middle of a data stream, Unicode says it should be interpreted as a "" (essentially a null character). In Unicode 3.2, this usage is deprecated in favour of the "Word Joiner" character, U+2060. This allows U+FEFF to be only used as a BOM.

[] UTF-8

The UTF-8 representation of the BOM is the byte sequence 0xEF,0xBB,0xBF. A text editor or web browser interpreting the text as or will display the characters  for this.

The Unicode Standard does permit the BOM in , but does not require or recommend its use. Byte order has no meaning in UTF-8 so in UTF-8 the BOM serves only to identify a text stream or file as UTF-8.

A reason the UTF-8 BOM is recommended against is that many pieces of software without Unicode support nevertheless are able to handle UTF-8 inside a text but not at the start of a text. For instance, the bytes of UTF-8 can be placed between the quotes of string constants in many programming languages, and that language will write the correct UTF-8 to a file or to a display, despite the language not knowing anything about UTF-8. This provides an easy migration path to convert systems to Unicode and to remove all legacy encodings, without simultaneously upgrading the programming language. The unexpected three bytes of the BOM break this however, as they are located where they are certain to be a syntax error.

A leading BOM can also defeat software that uses pattern matching on the start of a text file, since it inserts 3 bytes before the pattern. Though commonly associated with the Unix at the start of an interpreted script, the problem is more widespread. For instance in , the existence of a BOM will cause the page to begin output before the initial code is interpreted, causing problems if the page is trying to send custom HTTP headers (which must be set before output begins).

Many programs (including Windows ) add BOMs to UTF-8 files by default.

[] UTF-16

In , a BOM (U+FEFF) may be placed as the first character of a file or character stream to indicate the endianness (byte order) of all the 16-bit code units of the file or stream.

  • If the 16-bit units are represented in byte order, this BOM character will appear in the sequence of bytes as FE followed by 0xFF. This sequence appears as the characters þÿ in a text display that expects the text to be ISO-8859-1, although UTF-16 text will be more or less unreadable if the text display doesn't support UTF-16.
  • if the 16-bit units use order, the sequence of bytes will have 0xFF followed by 0xFE. This sequence appears as the characters ÿþ in a text display that expects the text to be ISO-8859-1.

Programs expecting UTF-8 may show these or error indicators, depending on how they handle UTF-8 encoding errors. In all cases they will probably display the rest of the file as garbage (a UTF-16 text containing ASCII only will be fairly readable).

For the registered charsets UTF-16BE and UTF-16LE, a byte order mark should not be used because the names of these character sets already determine the byte order. If encountered anywhere in such a text stream, U+FEFF is to be interpreted as a "zero width no-break space".

Clause D98 of conformance (section 3.10) of the Unicode standard states, "The UTF-16 encoding scheme may or may not begin with a BOM. However, when there is no BOM, and in the absence of a higher-level protocol, the byte order of the UTF-16 encoding scheme is big-endian." Whether or not a higher-level protocol is in force is open to interpretation. Files local to a computer for which the native byte ordering is little-endian, for example, might be argued to be encoded as UTF-16LE implicitly. Therefore the presumption of big-endian is widely ignored. When those same files are accessible on the Internet, on the other hand, no such presumption can be made. Searching for ASCII characters or just the space character (U+0020) is a method of determining the UTF-16 byte order.

[] UTF-32

Although a BOM could be used with , this encoding is rarely used for transmission. Otherwise the same rules as for are applicable.

[] Representations of byte order marks by encoding

Encoding Representation () Representation () Representation ()
EF BB BF 239 187 191 
() FE FF 254 255 þÿ
() FF FE 255 254 ÿþ
(BE) 00 00 FE FF 0 0 254 255 □□þÿ (□ is the ascii null character)
(LE) FF FE 00 00 255 254 0 0 ÿþ□□ (□ is the ascii null character)
2B 2F 76 38
2B 2F 76 39
2B 2F 76 2B
2B 2F 76 2F
43 47 118 56
43 47 118 57
43 47 118 43
43 47 118 47
+/v8
+/v9
+/v+
+/v/
F7 64 4C 247 100 76 ÷dL
DD 73 66 73 221 115 102 115 Ýsfs
0E FE FF 14 254 255 □þÿ (□ is the ascii "shift out" character)
FB EE 28 251 238 40 ûî
84 31 95 33 132 49 149 51 □1■3 (□ and ■ are unmapped ISO-8859-1 characters)
  1. ^ This is not really a "byte order" mark, since the byte is also the code unit in these encodings and there is no byte order to resolve. The sequence can be used to identify the encoding, however.
  2. In UTF-7, the fourth byte of the BOM, before encoding as , is 001111xx in binary, and xx depends on the next character (the first character after the BOM). Hence, technically, the fourth byte is not purely a part of the BOM, but also contains information about the next (non-BOM) character. For xx=00, 01, 10, 11, this byte is, respectively, 38, 39, 2B, or 2F when encoded as base64. If no following character is encoded, 38 is used for the fourth byte and the following byte is 2D.
  3. SCSU allows other encodings of U+FEFF, the shown form is the signature recommended in UTR #6.

转载地址:http://drqao.baihongyu.com/

你可能感兴趣的文章
测试LCD1602的显示,显示时间,提示语
查看>>
Linux常用命令
查看>>
SecureCRT 连接Ubuntu乱码解决
查看>>
一致性hash算法及其java实现
查看>>
PHP常见的加密技术
查看>>
Asp.net读取AD域信息的方法(一)
查看>>
两道题学习动态规划
查看>>
mysql实战31 | 误删数据后除了跑路,还能怎么办?
查看>>
ASP.NET MVC Razor
查看>>
Subscribe的第四个参数用法
查看>>
vue-cli的项目加入骨架屏
查看>>
3.SOAP和WSDL的一些必要知识
查看>>
python:使用OO和工厂模式解决问题
查看>>
C++学习-2
查看>>
mysql单表导入数据,全量备份导入单表
查看>>
GAITC 2019全球人工智能技术大会(南京)
查看>>
使用gradle生成protobuf
查看>>
transition transform animate的使用
查看>>
WebService_HelloWorld
查看>>
【翻译】Ext JS最新技巧——2014-5-12
查看>>