Cette page a été traduite à partir de l'anglais par la communauté.Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.
Math.imul()
Baseline Widely available
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis juillet 2015.
La fonctionMath.imul() renvoie le résultat de la multiplication de deux nombres, calculée avec la représentation sur 32 bits de ces nombres, à la façon du langage C.
Dans cet article
Exemple interactif
console.log(Math.imul(3, 4));// Expected output: 12console.log(Math.imul(-5, 12));// Expected output: -60console.log(Math.imul(0xffffffff, 5));// Expected output: -5console.log(Math.imul(0xfffffffe, 5));// Expected output: -10Syntaxe
Math.imul(a, b);Paramètres
Valeur de retour
Le résultat de la multiplication sur 32 bits des valeurs passées en argument (comme en C).
Description
Math.imul() permet d'effectuer une multiplication rapide pour des entiers sur 32 bits avec une sémantique proche du langage C. Cela est utile pour des aspects de performance, notamment pour des projets commeEmscripten.imul() étant une méthode statique deMath, il faut utiliserMath.imul() et non pas la méthode d'un autre objet qui aurait été créé (Math n'est pas un constructeur). Attention à l'utilisation de nombres flottants avecMath.imul() car cela implique une opération de conversion des flottants vers les entiers pour la multiplication puis une opération de conversion du résultat en flottant. Dans la pratique,Math.imul() est notamment pertinent pour asm.js.
Exemples
>UtiliserMath.imul()
Math.imul(2, 4); // 8Math.imul(-1, 8); //-8Math.imul(-2, -2); // 4Math.imul(0xffffffff, 5); //-5Math.imul(0xfffffffe, 5); //-10Prothèse d'émulation (polyfill)
Si elle n'est pas disponible, cette fonction peut être émulée de la façon suivante :
Math.imul = Math.imul || function (a, b) { var ah = (a >>> 16) & 0xffff; var al = a & 0xffff; var bh = (b >>> 16) & 0xffff; var bl = b & 0xffff; // Le décalage par 0 rétablit le signe de la partie haute // le |0 final convertit la valeur non-signée en une valeur signée return (al * bl + (((ah * bl + al * bh) << 16) >>> 0)) | 0; };Spécifications
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-math.imul> |