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

Accumulators

The EAX register is also known as an accumulator and is used with multiplication and division operations, both as implied and target operands. It is important to mention that the result of a binary multiplication is twice the size of the operands and the result of a binary division consists of two parts (quotient and remainder), each of which has the same bit width as the operands. Since the x86 architecture began with 16-bit registers and for the sake of backward compatibility, the EDX register is used for storing partial results when the values of the operands are larger than could fit into 8 bits. For example, if we want to multiply two bytes, 0x50 and 0x04, we would expect the result to be 0x140, which cannot be stored in a single byte. However, since the operands were 8 bits in size, the result is stored into the AX register, which is 16 bits. But if we want to multiply 0x150 by 0x104, the result would need 17 bits to be stored (0x150 * 0x104 = 0x15540) and, as we have mentioned already, the first x86 registers were only 16 bits. This is the reason for using an additional register; in the case of the Intel architecture, this register is EDX (to be more precise, only the DX part would be used in this specific case). As a verbal explanation may sometimes be too generalized, it would be better to simply demonstrate the rule.

Division implies a slightly different rule. To be more precise, this is the inverted multiplication rule, meaning that the result of the operation is half the bit width of the dividend, which in turn means that the largest dividend in the long mode may be 128-bit wide. The smallest dividend value remains the same as in the smallest value of the source operand in the case of multiplication--8 bits.

主站蜘蛛池模板: 金秀| 内江市| 玛沁县| 华阴市| 阳原县| 昌宁县| 清涧县| 安庆市| 滕州市| 奈曼旗| 崇州市| 杭锦后旗| 酉阳| 福鼎市| 乌拉特中旗| 泰顺县| 革吉县| 临江市| 巴中市| 江油市| 吉林市| 嵊州市| 北宁市| 高邮市| 房山区| 龙胜| 册亨县| 中江县| 芮城县| 米泉市| 富源县| 玉山县| 博乐市| 湘阴县| 芷江| 镇远县| 汽车| 宣城市| 昌都县| 义乌市| 海盐县|