Всё.....я уже ни чё не понимаю......(((((((((( как преобразовать двоичное число в десятичное(BCD)?размер двоичного 6 байт.....процессор 16разрядный..сопроцессор не использовать......
xds
12.11.2006 9:53
Цитата
в десятичное(BCD)
В упакованное (две цифры в байте, например 23d -> 23h) или неупакованное (одна цифра в байте, 23d -> 02h, 03h)?
F0b0s
12.11.2006 14:20
В упакованное
xds
12.11.2006 19:42
В виде вставок пойдёт?
Первый вариант (развёрнутые циклы):
program _bcd;
{$G+}const
Hex: array[0..15] of Char = '0123456789ABCDEF';
var
bin: array[0..5] of Byte;
bcd: array[0..7] of Byte;
t: LongInt absolute bin;
i: Integer;
begin
t := 123456789;
{ t := 987654321; }asm
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[7],ah
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[6],ah
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[5],ah
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[4],ah
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[3],ah
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[2],ah
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[1],ah
call @@div10
mov dx,ax
call @@div10
shl ah,4
or ax,dx
mov byte ptr bcd[0],ah
jmp @@exit
@@div10:
mov cl,10
xor ax,ax
mov al,byte ptr bin[5]
div cl
mov byte ptr bin[5],al
mov al,byte ptr bin[4]
div cl
mov byte ptr bin[4],al
mov al,byte ptr bin[3]
div cl
mov byte ptr bin[3],al
mov al,byte ptr bin[2]
div cl
mov byte ptr bin[2],al
mov al,byte ptr bin[1]
div cl
mov byte ptr bin[1],al
mov al,byte ptr bin[0]
div cl
mov byte ptr bin[0],al
ret
@@exit:
endfor i := 0to7do
Write(Hex[bcd[i] shr4], Hex[bcd[i] and$F]);
Writeln;
end.
Второй вариант (циклы на основе "loop"):
program bcd2;
{$G+}const
Hex: array[0..15] of Char = '0123456789ABCDEF';
var
bin: array[0..5] of Byte;
bcd: array[0..7] of Byte;
t: LongInt absolute bin;
i: Integer;
begin
t := 123456789;
{ t := 987654321; }asm
push si
push di
push ds
pop es
std
lea di,bcd[7]
mov cx,8
@@store:
push cx
call @@div10
mov bx,ax
call @@div10
shl ah,4
or ax,bx
mov al,ah
stosb
pop cx
loop @@store
jmp @@exit
@@div10:
mov dl,10
xor ax,ax
lea si,bin[5]
mov cx,6
@@div:
lodsb
div dl
mov [si+1],al
loop @@div
ret
@@exit:
pop di
pop si
endfor i := 0to7do
Write(Hex[bcd[i] shr4], Hex[bcd[i] and$F]);
Writeln;
end.
F0b0s
12.11.2006 21:09
Я так понял что суть твоего решения заключается в том что ты каждый байт двоичного числа поочереди делишь на десятичное 10, тем самым остаток и является десятичным разрядом...но результат будет не один и тот же если делить побайтно и делить все 6 байт сразу на 10....или я не прав???? Расскажи мне лучше как мне разделить вс 6 байт сразу на 10d
xds
12.11.2006 21:20
Цитата
но результат будет не один и тот же если делить побайтно и делить все 6 байт сразу на 10....или я не прав????
Все зависит от того, что подразумевается под словом "побайтно"
Здесь реализовано полноценное деление 48-битного двоичного числа на 10 (перенос осуществляется через ah). Оно выполняется побайтно за 6 интераций.
Цитата
Расскажи мне лучше как мне разделить вс 6 байт сразу на 10d
Это возможно только в 48-и и более разрядной архитектуре
F0b0s
12.11.2006 21:58
ВСЁ понял.....спасибо
Это ещё возможно с использованием сопроцессора
М
невозможно, если читать первый пост
xds
12.11.2006 22:03
Цитата(F0b0s @ 13.11.2006 0:58)
ВСЁ понял.....спасибо
Это ещё возможно с использованием сопроцессора
Ага Можно ещё использовать 16-битное деление.
F0b0s
17.11.2006 23:07
Вот сам тут кое чё написал.....тока преобразование не в BCD а в ASCII....то из одного другое сделать не сложно.....
NAME;...........................................
DataSEGMENT
X1 DQ 000012345678ABCDh
R DB 15 DUP(0)
DataENDS;...........................................
CodeSEGMENTASSUMECS:Code,DS:Data;...........................................
Start: MOV AX,Data
MOV DS,AX
LEA SI,X1
LEA BX,R
MOV DI,10
MOV BP,15
ADD SI,(type X1 -2)
M2: XOR Dl,DL
MOV CX,4
M1: MOV AX,[SI]
DIV DI
MOV [SI],AX
SUB SI,2
DEC CXJNZ M1
MOV [BX],Dl
LEA SI,X1
ADD SI,(type X1-2)
INC BX
DEC BPJNZ M2
CodeENDSENDStart
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.