官术网_书友最值得收藏!

Endianness

When reading or writing data to memory, we use the registers or memory to process them as BYTE, WORD, DWORD, or even QWORD. Depending on the platform or program, data is read in little-endian or big-endian form.

In little-endian, a chunk of data read into a DWORD is reversed. Let's take the following piece of data as an example:

AA BB CC DD

When the data on a file or memory looks like this, in little-endian format, it will be read as DDCCBBAAh in a DWORD value. This endianness is common to Windows applications.

In the big-endian system, the same chunk of data will be read as AABBCCDDh. The advantage of using the big-endian form arises when reading streaming data such as file, serial, and network streams.

The advantage of reading in little-endian is that the address you read it from remains fixed, regardless of whether it is read as BYTE, WORD, or DWORD. For example, consider the following:

Address       Byte
0x00000000 AA
0x00000001 00
0x00000002 00
0x00000003 00

In the preceding example, we attempt to read the data from address the 0x00000000 address. When read as BYTE, it will be AAh. When read as a WORD, it will be AAh. When read as a DWORD, it will be AAh.

But when in big endian, when read as a BYTE, it will be AAh. When read as a WORD, it will be AA00h. When read as a DWORD, it will be AA000000h.

There are actually a lot more advantages over the other. Either of these can be used by an application depending on its purpose. In x86 assembly, the little-endian format is the standard.

主站蜘蛛池模板: 新疆| 淮南市| 承德市| 白银市| 郴州市| 临城县| 宁蒗| 始兴县| 松阳县| 甘谷县| 法库县| 徐闻县| 亳州市| 吐鲁番市| 平度市| 和田县| 嘉善县| 靖西县| 陆河县| 梁平县| 安西县| 翁源县| 兴文县| 哈密市| 读书| 长子县| 中阳县| 景宁| 华阴市| 奇台县| 新源县| 水城县| 双峰县| 昆山市| 锡林郭勒盟| 佛山市| 崇义县| 连平县| 金山区| 沧州市| 深圳市|