gpt4 book ai didi

c++ - __int64 在 32 位机器上?

转载 作者:IT老高 更新时间:2023-10-28 12:59:47 27 4
gpt4 key购买 nike

我刚刚在我的 32 位机器上尝试了 MSVC 2010 中的一些东西,发现我可以在我的程序中使用 __int64 - 这确实有效!

这怎么可能?

最佳答案

32 位算法在 16 位系统上的工作方式相同。

在这种情况下,它使用 2 个 32 位的内存地址一起组成一个 64 位的数字。加法/减法很容易,你可以分部分来做,唯一的问题就是从较低的部分到较高的部分进行结转。对于乘法/除法,它更难(即更多指令)。

它显然很慢,比用于乘法的 32 位算术要慢很多,但如果你需要它,它就在那里。当您升级到 64 位 processor 编译器时,它会自动优化为具有更大字长的一条指令。

在 Release模式下编译的 32 位处理器上的 64 位乘法的 Visual Studio 2010 Professional 实现是:

_allmul PROC NEAR

A EQU [esp + 4] ; stack address of a
B EQU [esp + 12] ; stack address of b

mov eax,HIWORD(A)
mov ecx,HIWORD(B)
or ecx,eax ;test for both hiwords zero.
mov ecx,LOWORD(B)
jnz short hard ;both are zero, just mult ALO and BLO

mov eax,LOWORD(A)
mul ecx

ret 16 ; callee restores the stack

hard:
push ebx

A2 EQU [esp + 8] ; stack address of a
B2 EQU [esp + 16] ; stack address of b

mul ecx ;eax has AHI, ecx has BLO, so AHI * BLO
mov ebx,eax ;save result

mov eax,LOWORD(A2)
mul dword ptr HIWORD(B2) ;ALO * BHI
add ebx,eax ;ebx = ((ALO * BHI) + (AHI * BLO))

mov eax,LOWORD(A2) ;ecx = BLO
mul ecx ;so edx:eax = ALO*BLO
add edx,ebx ;now edx has all the LO*HI stuff

pop ebx

ret 16 ; callee restores the stack

如您所见,它比普通乘法慢很多。

关于c++ - __int64 在 32 位机器上?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2692329/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com