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

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.

主站蜘蛛池模板: 通化市| 巴中市| 化隆| 泸定县| 黄龙县| 南江县| 自治县| 红河县| 宁国市| 连南| 威宁| 腾冲县| 临沭县| 长宁区| 巧家县| 宁河县| 岗巴县| 乐陵市| 会宁县| 万州区| 澜沧| 潍坊市| 通江县| 宣武区| 桐庐县| 马尔康县| 扎兰屯市| 虹口区| 江山市| 三门县| 乐山市| 萨嘎县| 贵南县| 宁夏| 怀集县| 师宗县| 织金县| 宾阳县| 扎囊县| 尤溪县| 绥化市|