9 / 9 / 10
Регистрация: 05.09.2013
Сообщений: 502
|
||||||
1 | ||||||
Умножение двух 16-ти разрядных чисел10.09.2013, 19:25. Показов 18979. Ответов 61
Метки нет Все метки)
(
Здравствуйте . Помогите , пожалуйста, понять , как умножаются числа в ассемблере.
Читал , что если ax* на 16-ти разрядное число , то результат будет записываться в виде dx:ax , старшая часть в dx , а младшая в ax . Как это понимать ? Например , если я пишу вот так:
Как , например , потом отнять /добавить какое-то число к этому результату?
0
|
|
10.09.2013, 19:25 | |
Ответы с готовыми решениями:
61
Умножение двух 32-разрядных беззнаковых целых чисел (нужна проверка решения)
Вычитание двух 32-разрядных двоичных чисел Умножение двух 64-х разрядных чисел на 64битной системе |
Модератор
3489 / 2612 / 741
Регистрация: 19.09.2012
Сообщений: 7,973
|
|
10.09.2013, 19:58 | 2 |
Например, если перемножить два 16-ти битных числа ABCD и DCBA, то результат будет 9420FEF2, что явно больше 16-ти бит и в ax его уже не запихать. Поэтому, младшая часть числа (FEF2) записываетсяв ax, а старшая (9420) - в dx.
0
|
9 / 9 / 10
Регистрация: 05.09.2013
Сообщений: 502
|
|
10.09.2013, 20:15 [ТС] | 3 |
0
|
Модератор
![]() 8876 / 6651 / 912
Регистрация: 14.02.2011
Сообщений: 23,424
|
|
10.09.2013, 20:25 | 4 |
целому результату чего?
вот у тебя есть число(берем десятичные чтобы было понятно) 1000 * 1000 и есть четыре клетки чтобы записать результат (AX) получится (младшие) 0000 но есть еще четыре дополнительных клетки( DX) в них запишется (старшие)100 в общем (0100) (0000) и что есть для тебя результат ?
0
|
Модератор
3489 / 2612 / 741
Регистрация: 19.09.2012
Сообщений: 7,973
|
|
10.09.2013, 20:28 | 5 |
NNN7, надо сдвинуть содержимое edx на 16 разрядов влево и сложить его с eax - получится "целый" результат.
0
|
Модератор
3489 / 2612 / 741
Регистрация: 19.09.2012
Сообщений: 7,973
|
|
10.09.2013, 20:44 | 7 |
edx - 32-х разрядный регистр, вообщето.
Если я сложу 94200000 с FEF2, то получу 9420FEF2. Как у тебя с этим обстоит - не знаю.
0
|
9 / 9 / 10
Регистрация: 05.09.2013
Сообщений: 502
|
|
10.09.2013, 20:44 [ТС] | 8 |
Спасибо за Ваш ответ. В ax и dx немного понятно .
На счёт целого результата: вот я пусть умножил два 16-ти разрядных числа A и B , образовались ax с младшими разрядами и dx с старшими разрядами . Но дальше мне нужно до этого произведения добавить какую-то цифру . Как это сделать , если результат разбит на 2 регистра ? Вот этого не могу понять (
0
|
Модератор
![]() 8876 / 6651 / 912
Регистрация: 14.02.2011
Сообщений: 23,424
|
||||||
10.09.2013, 21:03 | 9 | |||||
а теперь открываем стартовый пост и удивляемся
речь идет о 16 битных регистрах
покажи где ты
вот по твоему
94200000>>16=9420 9420+FEF2 никак не получится 9420FEF2. добавляй к младшему разряду ax если будет переполнение то добавляй к старшему разряду 1 вспомни математику 1-2 класс сложение столбиком примерно будет выглядеть так
Добавлено через 5 минут расшифровываю add сложение двух операндов с записью результата в левый операнд adc сложение двух операндов с записью результата в левый операнд плюс флаг переноса (0 если не установлен, 1 если установлен)
0
|
Модератор
3489 / 2612 / 741
Регистрация: 19.09.2012
Сообщений: 7,973
|
|
10.09.2013, 21:05 | 10 |
Я отвечал на вопрос:
(Помимо стартового поста бывают и другие...) По-моему, лево находится с другой стороны.
0
|
Модератор
3489 / 2612 / 741
Регистрация: 19.09.2012
Сообщений: 7,973
|
|
10.09.2013, 21:15 | 12 |
После умножения в edx будет 00009420.
00009420 << 16 = 94200000
0
|
9 / 9 / 10
Регистрация: 05.09.2013
Сообщений: 502
|
|
10.09.2013, 21:15 [ТС] | 13 |
Спасибо за ответ ) А где опять же хранится результат нашего сложения ? В ax ?
А как поступать с вычитанием ? Если , например , есть такой пример : A-(B*C). Извините , что достаю Вас вопросами )
0
|
programmer
2391 / 525 / 69
Регистрация: 01.06.2011
Сообщений: 3,639
|
||||||
10.09.2013, 21:16 | 14 | |||||
влево-не вправо!
(9420<<16) + FEF2=9420FEF2; NNN7,если приходиться работать с 16 разрядными регистрами,то прибавлять необходимо к младшей части числа. При условии,что прибавляем 16 разрядное число.Если происходит переполнение,то делать инкримент старшей части в dx. Опять все зависит от условий задачи.это примерный вариант.
0
|
9 / 9 / 10
Регистрация: 05.09.2013
Сообщений: 502
|
|
10.09.2013, 22:00 [ТС] | 15 |
0
|
Модератор
![]() 8876 / 6651 / 912
Регистрация: 14.02.2011
Сообщений: 23,424
|
||||||||||||||||
10.09.2013, 22:09 | 16 | |||||||||||||||
гаспада я с вас балдею
![]() откуда взялось число 9420? отсюда??? если я напишу (32 битный режим)
если напишу так (16 битный режим)
ну и куда я должен сдвигать DX( на 16 разрядов в 16разрядном регистре) и как должен складывать с AX????? не надо путать режимы в DX (EDX) записывается то что не влезло а AX(EAX) а теперь прошу код как можно умножать 16 битку( а главное зачем) и потом это переводить в 32х битку в AX младшие разряды в DX старшие (это такое большое число которое уже не влазит в AX) прочитай что такое sub и sbb ну можно например так
Добавлено через 1 минуту ADC использовать религия не позволяет?
0
|
9 / 9 / 10
Регистрация: 05.09.2013
Сообщений: 502
|
|
10.09.2013, 22:27 [ТС] | 17 |
0
|
Модератор
3489 / 2612 / 741
Регистрация: 19.09.2012
Сообщений: 7,973
|
|
10.09.2013, 22:29 | 18 |
0
|
Модератор
3489 / 2612 / 741
Регистрация: 19.09.2012
Сообщений: 7,973
|
||||||
10.09.2013, 22:55 | 20 | |||||
0
|
10.09.2013, 22:55 | |
10.09.2013, 22:55 | |
Помогаю со студенческими работами здесь
20
Схема умножение двух 8-ми разрядных двоичных чисел AT90S1200. Умножение 4-х разрядных чисел на ASM МС68HC11 (Micro-IDE). Умножение двоично-десятичных 8-разрядных чисел Сложение, вычитание и умножение 32-разрядных чисел в формате с плавающей точкой (float) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |