分享方式:


__emul、__emulu

Microsoft 特定的

執行溢位32位整數所能保存的乘法。

語法

__int64 __emul(
   int a,
   int b
);
unsigned __int64 __emulu(
   unsigned int a,
   unsigned int b
);

參數

a
[in]乘法的第一個整數操作數。

b
[in]乘法的第二個整數操作數。

傳回值

乘法的結果。

需求

內建 架構
__emul x86、x64
__emulu x86、x64

頭檔<intrin.h>

備註

__emul 會採用兩個 32 位帶正負號的值,並以 64 位帶正負號的整數值傳回乘法的結果。

__emulu 會採用兩個 32 位無符號整數值,並以 64 位無符號整數值傳回乘結果。

範例

// emul.cpp
// compile with: /EHsc
// processor: x86, x64
#include <iostream>
#include <intrin.h>
using namespace std;

#pragma intrinsic(__emul)
#pragma intrinsic(__emulu)

int main()
{
   int a = -268435456;
   int b = 2;

   __int64 result = __emul(a, b);

   cout << a << " * " << b << " = " << result << endl;

   unsigned int ua = 0xFFFFFFFF; // Dec value: 4294967295
   unsigned int ub = 0xF000000;  // Dec value: 251658240

   unsigned __int64 uresult = __emulu(ua, ub);

   cout << ua << " * " << ub << " = " << uresult << endl;

}

輸出

-268435456 * 2 = -536870912
4294967295 * 251658240 = 1080863910317260800

END Microsoft 特定的

另請參閱

編譯程式內部函數