| 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")}}
 |