1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
---
title: Math.clz32()
slug: Web/JavaScript/Reference/Global_Objects/Math/clz32
tags:
- ECMAScript 2015
- JavaScript
- Math
- Méthode
- Reference
- polyfill
translation_of: Web/JavaScript/Reference/Global_Objects/Math/clz32
original_slug: Web/JavaScript/Reference/Objets_globaux/Math/clz32
---
{{JSRef}}
La fonction **`Math.clz32()`** renvoie le nombre de zéros de tête dans la représentation binaire sur 32 bits d'un nombre.
{{EmbedInteractiveExample("pages/js/math-clz32.html")}}
## Syntaxe
Math.clz32(x)
### Paramètres
- `x`
- : Un nombre.
### Valeur retournée
Le nombre de bits à zéro en tête de la représentation binaire sur 32 bits du nombre donné.
## Description
"`clz32`" est un raccourci pour CountLeadingZeroes32 (en français, « compter les zéros de tête »).
Si `x` n'est pas un nombre, il sera d'abord converti en nombre puis converti en un entier non signé sur 32 bits.
Si l'entier non signé sur 32 bits résultant vaut `0`, la fonction renverra `32`, car tous les bits valent `0`.
Cette fonction est particulièrement utile aux systèmes qui compilent du code JavaScript, comme [Emscripten](/fr/docs/Emscripten).
## Exemples
```js
Math.clz32(1) // 31
Math.clz32(1000) // 22
Math.clz32() // 32
var liste = [NaN, Infinity, -Infinity, 0, -0, null, undefined, 'machin', {}, []];
liste.every(n => Math.clz32(n) == 32); // true
Math.clz32(true) // 31
Math.clz32(3.5) // 30
```
## Spécifications
| Spécification | Statut | Commentaire |
| ---------------------------------------------------------------------------- | ---------------------------- | -------------------- |
| {{SpecName('ES2015', '#sec-math.clz32', 'Math.clz32')}} | {{Spec2('ES2015')}} | Définition initiale. |
| {{SpecName('ESDraft', '#sec-math.clz32', 'Math.clz32')}} | {{Spec2('ESDraft')}} | |
## Compatibilité des navigateurs
{{Compat("javascript.builtins.Math.clz32")}}
## Voir aussi
- {{jsxref("Math")}}
- {{jsxref("Math.imul")}}
|