首先,我对 8086 组件非常陌生,掌握知识对我来说非常困难。尽管如此,我会尽力而为。
我一直在尝试编写代码来生成 0-9 范围内的随机数。在查看了几个示例和建议之后,这就是我最终得到的。为了简单起见,我没有对检索到的时钟计数应用任何数学函数,而且我认为这是不必要的。由于某些原因,我最终生成的某些数字比诸如 1,3 和 9 之类的数字少 6,7 次。我相信这是因为我采用了时钟滴答的低阶,其中值发生了变化迅速。
我的目的是模拟掷骰子,后来将以下代码的范围更改为 1-6。我的问题是,这足以满足我的目的吗?还是有更好的方法来做到这一点?
代码:
RANDGEN: ; generate a rand no using the system time
RANDSTART:
MOV AH, 00h ; interrupts to get system time
INT 1AH ; CX:DX now hold number of clock ticks since midnight
; lets just take the lower bits of DL for a start..
MOV BH, 57 ; set limit to 57 (ASCII for 9)
MOV AH, DL
CMP AH, BH ; compare with value in DL,
JA RANDSTART ; if more, regenerate. if not, continue...
MOV BH, 49 ; set limit to 48 (ASCII FOR 0)
MOV AH, DL
CMP AH, BH ; compare with value in DL
JB RANDSTART ; if less, regenerate.
; if not, this is what we need
mov ah, 2h ; call interrupt to display a value in DL
int 21h
RET
由@johnfound 回答:
我发现他的方法更简单,生成随机数所需的时间更少。他提到这仅在您需要一个随机数时才有效,或者随机数之间的间隔包括人工输入的暂停。如果不是,这些数字根本不会是随机的(我相信由于我们最初采用的时间种子不会改变)。这对我来说很好,因为我正在模拟一个掷骰子,并且在我再次运行代码之前我需要用户干预(另一个掷骰子)。
RANDGEN: ; generate a rand no using the system time
RANDSTART:
MOV AH, 00h ; interrupts to get system time
INT 1AH ; CX:DX now hold number of clock ticks since midnight
mov ax, dx
xor dx, dx
mov cx, 10
div cx ; here dx contains the remainder of the division - from 0 to 9
add dl, '0' ; to ascii from '0' to '9'
mov ah, 2h ; call interrupt to display a value in DL
int 21h
RET
他做了什么: 1.我们将 DX 中的价值转移到 AX 2.我们清除 DX。3.我们在 12 月 10 日搬到了 CX。4.我们将 AX 除以 CX,因此我们在 12 月 0-9 日内得到一个余数,该余数存储在 DX 中 5.最后,我们将 ASCII '0'(dec 48)添加到 DX 以将它们转换为 ASCII '0' 到 '9' .