From a3efc50f26d87c20c2f07f14772cf0d57d0f4fc3 Mon Sep 17 00:00:00 2001 From: SphinxKnight Date: Sun, 19 Dec 2021 07:01:37 +0100 Subject: Translation of FinalizationRegistry pages (#3153) --- .../finalizationregistry/index.md | 51 +++++++++ .../global_objects/finalizationregistry/index.md | 123 +++++++++++++++++++++ .../finalizationregistry/register/index.md | 61 ++++++++++ .../finalizationregistry/unregister/index.md | 113 +++++++++++++++++++ 4 files changed, 348 insertions(+) create mode 100644 files/fr/web/javascript/reference/global_objects/finalizationregistry/finalizationregistry/index.md create mode 100644 files/fr/web/javascript/reference/global_objects/finalizationregistry/index.md create mode 100644 files/fr/web/javascript/reference/global_objects/finalizationregistry/register/index.md create mode 100644 files/fr/web/javascript/reference/global_objects/finalizationregistry/unregister/index.md (limited to 'files/fr') diff --git a/files/fr/web/javascript/reference/global_objects/finalizationregistry/finalizationregistry/index.md b/files/fr/web/javascript/reference/global_objects/finalizationregistry/finalizationregistry/index.md new file mode 100644 index 0000000000..8416bc5a54 --- /dev/null +++ b/files/fr/web/javascript/reference/global_objects/finalizationregistry/finalizationregistry/index.md @@ -0,0 +1,51 @@ +--- +title: Constructeur FinalizationRegistry() +slug: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/FinalizationRegistry +translation_of: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/FinalizationRegistry +browser-compat: javascript.builtins.FinalizationRegistry.FinalizationRegistry +--- +{{JSRef}} + +Le constructeur **`FinalizationRegistry`** crée un objet [`FinalizationRegistry`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry) qui utilise la fonction de rappel passée en argument comme fonction de nettoyage pour les objets du registre. + +## Syntaxe + +```js +// Fonction de rappel avec une fonction fléchée +new FinalizationRegistry(valeurTenue => { ... } ) + +// Référence à une fonction de rappel +new FinalizationRegistry(callbackFn) + +// Fonction de rappel en ligne +new FinalizationRegistry(function(valeurTenue) { ... }) +``` + +### Paramètres + +- `callback` + - : La fonction de rappel de nettoyage à utiliser par le registre. + +## Exemples + +### Créer un nouveau registre + +On crée le registre en fournissant la fonction de rappel : + +```js +const registre = new FinalizationRegistry(valeurTenue => { + // .... +}); +``` + +## Spécifications + +{{Specifications}} + +## Compatibilité des navigateurs + +{{Compat}} + +## Voir aussi + +- [`FinalizationRegistry`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry) diff --git a/files/fr/web/javascript/reference/global_objects/finalizationregistry/index.md b/files/fr/web/javascript/reference/global_objects/finalizationregistry/index.md new file mode 100644 index 0000000000..e81a29d381 --- /dev/null +++ b/files/fr/web/javascript/reference/global_objects/finalizationregistry/index.md @@ -0,0 +1,123 @@ +--- +title: FinalizationRegistry +slug: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry +translation_of: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry +browser-compat: javascript.builtins.FinalizationRegistry +--- +{{JSRef}} + +Un objet **`FinalizationRegistry`** permet de déclencher une fonction de rappel (callback) lorsqu'un objet est récupéré par le ramasse-miettes. + +## Description + +`FinalizationRegistry` fournit une méthode pour demander à ce qu'une fonction de nettoyage soit appelée à un moment lorsqu'un objet enregistré dans le registre de mémoire a été _récupéré_ (traité par le ramasse-miettes). Ces fonctions de rappel pour du nettoyage sont parfois appelées _finaliseurs_. + +> **Note :** Ces fonctions de rappels ne devraient pas être utilisées pour des opérations essentielles à la logique d'un programme. Voir les notes ci-après pour plus de détails. + +On crée le registre en passant la fonction de rappel en paramètre : + +```js +const registre = new FinalizationRegistry(valeurTenue => { + // … +}); +``` + +Ensuite, avec la méthode `register` on inscrit au registre les différents objets pour lesquels on veut que la fonction de rappel de nettoyage soit appelée. Cette fonction prend en argument la valeur courante et une *valeur tenue* pour celle-ci : + +```js +registre.register(unObjet, "une valeur"); +``` + +Le registre ne conserve pas de référence forte vers l'objet, cela irait contre son objectif premier, car l'objet ne serait alors jamais traité par le ramasse-miettes. + +Lorsque `unObjet` est récupéré, la fonction de rappel de nettoyage pourra être appelée à un moment avec la _valeur tenue_ fournie (`"une valeur"` dans l'exemple qui précède). La valeur tenue peut être n'importe quelle valeur : une valeur primitive, un objet, même `undefined`. Si la valeur tenue est un objet, le registre conservera une référence _forte_ vers celle-ci (afin de pouvoir la passer comme argument à la fonction de rappel de nettoyage). + +Si vous souhaitez retirer un objet du registre plus tard, on passera un troisième argument à la méthode `register`. Cet argument sera _le jeton de désenregistrement_ qui sera utilisé plus tard avec la méthode `unregister` afin de retirer l'objet du registre. Le registre ne conserve qu'une référence faible pour le jeton de désenregistrement. + +Une pratique fréquente consiste à utiliser l'objet lui-même comme jeton, ce qui fonctionne sans problème : + +```js +registre.register(unObjet, "une valeur", unObjet); +// …plus tard si on ne s'intéresse plus à `unObjet`… +registre.unregister(unObjet); +``` + +Il n'est toutefois pas nécessaire que ce soit le même objet, on peut tout à fait utiliser une autre valeur : + +```js +registre.register(unObjet, "une valeur", objetJeton); +// …plus tard si on ne s'intéresse plus à `unObjet`… +registre.unregister(objetJeton); +``` + +## Constructeur + +- [`FinalizationRegistry()`](/fr/docs/Web/JavaScript/Reference/FinalizationRegistry/FinalizationRegistry) + - : Crée un nouvel objet `FinalizationRegistry`. + +## Méthodes de l'instance + +- [`FinalizationRegistry.prototype.register()`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/register) + - : Enregistre un objet dans le registre afin de pouvoir déclencher une fonction de rappel de nettoyage lorsque l'objet est traité par le ramasse-miettes. +- [`FinalizationRegistry.prototype.unregister()`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/unregister) + - : Retire un objet du registre. + +## À éviter si possible + +Une utilisation correcte de `FinalizationRegistry` nécessite une réflexion suffisante et il est préférable d'avoir à utiliser ces traitements si possible. Il est également important d'éviter d'avoir à dépendre de fonctionnements spécifiques non garantis par la spécification. Le moment, la façon et l'exécution même du ramasse-miettes dépendent éminemment de l'implémentation du moteur JavaScript. Tout comportement observé pour un moteur pourra être différent dans un autre moteur, dans une version différente du même moteur ou encore même dans une situation légèrement différente et pour la même version du même moteur. La gestion du ramasse-miettes est un problème complexe sur lequel travaillent constamment les personnes qui implémentent les moteurs JavaScript. + +Voici quelques sujets spécifiques inclus dans [le document explicatif de la proposition correspondante](https://github.com/tc39/proposal-weakrefs/blob/master/reference.md) : + +> [Les ramasses-miettes](https://fr.wikipedia.org/wiki/Ramasse-miettes_(informatique)) sont compliqués. Si une application ou une bibliothèque dépend d'un ramasse-miettes nettoyant un registre FinalizationRegistry ou appelant un finaliseur de façon précise et prédictible, qu'elle se prépare à être déçue : le nettoyage pourra avoir lieu bien plus tard que prévu voire pas du tout. Ce comportement grandement variable est dû : +> +> - Au fait qu'un objet peut être récupéré par le ramasse-miettes bien plus tôt qu'un autre, même s'il devient inaccessible au même temps, par exemple en raison du ramassage générationnel. +> - À l'action du ramasse-miettes qui peut être divisée dans le temps en utilisant des techniques incrémentales et concurrentes. +> - À des heuristiques d'exécution qui peuvent être utilisées afin d'équilibrer l'usage de la mémoire et la réactivité. +> - Au moteur JavaScript qui pourra tenir des références envers des choses qui semblent inaccessibles (comme des fermetures ou des caches en ligne). +> - À la différence des moteurs JavaScript ou au changement d'algorithmes pour un même moteur au fur et à mesure de ses différentes versions. +> - À des facteurs complexes pouvant maintenir en vie des objets pendant une période indéfinie comme avec l'utilisation de certaines API. + +## Notes quant aux fonctions de rappel de nettoyage + +Quelques notes à propos des fonctions de rappel de nettoyage : + +- On ne doit pas faire reposer une logique essentielle d'un programme sur les fonctions de rappel de nettoyage. Ces dernières peuvent être utiles afin de réduire l'utilisation de la mémoire pendant la vie d'un programme mais seront vraisemblablement inutiles autrement. +- Une implémentation JavaScript conforme, y compris parmi celles qui implémentent un ramasse-miettes, n'est pas tenue d'appeler les fonctions de rappel de nettoyage. Le moment et l'éventualité de cet appel est entièrement dépendant des choix d'implémentation du moteur JavaScript. Lorsqu'un objet enregistré est récupéré, toute fonction de rappel de nettoyage déclarée pourra être appelée sur le coup, plus tard ou jamais. +- Il est probable que les implémentations majeures des moteurs appelleront les fonctions de rappel de nettoyage à un moment pendant l'exécution mais ces appels pourront arriver bien après que l'objet en question ait été récupéré. +- Il existe des situations où même les implémentations qui appellent ces fonctions de rappel ont peu de chance de les invoquer : + - Lorsque le programme JavaScript s'interrompt entièrement (par exemple, lorsqu'on ferme un onglet dans un navigateur). + - Lorsque l'instance de `FinalizationRegistry`, elle-même, n'est plus accessible depuis le reste du code JavaScript. + +## Exemples + +### Créer un nouveau registre + +On crée le registre en y passant la fonction de rappel : + +```js +const registre = new FinalizationRegistry(valeurTenue => { + // .... +}); +``` + +### Enregistrer des objets en vue de leur nettoyage + +Ensuite, on enregistre les objets pour lesquels on souhaite avoir la fonction de rappel de nettoyage exécutée. Pour cela, on appelle la méthode `register` en lui passant l'objet et une *valeur tenue* correspondante : + +```js +registre.register(unObjet, "une valeur"); +``` + +## Spécifications + +{{Specifications}} + +## Compatibilité des navigateurs + +{{Compat}} + +## Voir aussi + +- [`WeakRef`](/fr/docs/Web/JavaScript/Reference/Global_Objects/WeakRef) +- [`WeakSet`](/fr/docs/Web/JavaScript/Reference/Global_Objects/WeakSet) +- [`WeakMap`](/fr/docs/Web/JavaScript/Reference/Global_Objects/WeakMap) diff --git a/files/fr/web/javascript/reference/global_objects/finalizationregistry/register/index.md b/files/fr/web/javascript/reference/global_objects/finalizationregistry/register/index.md new file mode 100644 index 0000000000..b9be96d21b --- /dev/null +++ b/files/fr/web/javascript/reference/global_objects/finalizationregistry/register/index.md @@ -0,0 +1,61 @@ +--- +title: FinalizationRegistry.prototype.register() +slug: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/register +translation_of: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/register +browser-compat: javascript.builtins.FinalizationRegistry.register +--- +{{JSRef}} + +La méthode `register()` inscrit un objet dans un registre [`FinalizationRegistry`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry) afin que, lorsque l'objet est traité par le ramasse-miettes, la fonction de rappel de nettoyage associée puisse être appelée. + +## Syntaxe + +```js +register(cible, valeurTenue); +register(cible, valeurTenue, jetonDesenregistrement); +``` + +### Paramètres + +- `cible` + - : L'objet cible à inscrire au registre. +- `valeurTenue` + - : La valeur à passer au finaliseur pour cet objet. Cette valeur ne peut pas être l'objet `cible`. +- `jetonDesenregistrement` {{optional_inline}} + - : Un jeton qui peut être utilisé par la méthode `unregister()` plus tard pour retirer l'objet cible du registre. Si cette valeur est fournie (et est différente de `undefined`), ce doit être un objet. Si cette valeur n'est pas fournie, l'objet cible ne peut pas être retiré du registre. + +### Valeur de retour + +`undefined`. + +## Notes + +Voir les notes de la page [`FinalizationRegistry`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry#avoid_where_possible) à propos d'inconvénients sur l'utilisation de ces outils. + +## Exemples + +### Utiliser register() + +La ligne suivante enregistre l'objet `cible` et passe la valeur tenue `"une valeur"` et l'objet cible comme jeton de désenregistrement : + +```js +registry.register(cible, "une valeur", cible); +``` + +La ligne suivante enregistre l'objet `cible` et passe un autre objet comme valeur tenue. L'absence de jeton de désenregistrement indique que `cible` ne peut pas être retiré du registre) : + +```js +registry.register(cible, {"utile": "info à propos de la cible"}); +``` + +## Spécifications + +{{Specifications}} + +## Compatibilité des navigateurs + +{{Compat}} + +## Voir aussi + +- [`FinalizationRegistry`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry) diff --git a/files/fr/web/javascript/reference/global_objects/finalizationregistry/unregister/index.md b/files/fr/web/javascript/reference/global_objects/finalizationregistry/unregister/index.md new file mode 100644 index 0000000000..a9ed6b5930 --- /dev/null +++ b/files/fr/web/javascript/reference/global_objects/finalizationregistry/unregister/index.md @@ -0,0 +1,113 @@ +--- +title: FinalizationRegistry.prototype.unregister() +slug: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/unregister +translation_of: Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/unregister +browser-compat: javascript.builtins.FinalizationRegistry.unregister +--- +{{JSRef}} + +La méthode `unregister()` permet de retirer un objet donné d'un registre [`FinalizationRegistry`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry). + +## Syntaxe + +```js +unregister(jetonDesenregistrement); +``` + +### Paramètres + +- `jetonDesenregistrement` + - : Le jeton utilisé par la méthode [`register()`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry/register) lors de l'enregistrement de l'objet cible. + +### Valeur de retour + +`undefined`. + +## Notes + +Lorsqu'un objet cible a été récupéré, il ne fait plus partie du registre. Aussi, il n'est pas nécessaire d'utiliser `unregister()` dans les fonctions de rappel de nettoyage. Appelez uniquement `unregister` si vous n'avez pas reçu de fonction de rappel de nettoyage et que vous n'en avez plus besoin. + +## Exemples + +### Utiliser unregister() + +Cet exemple illustre l'enregistrement d'un objet en l'utilisant lui-même comme jeton pour le retirer du registre par la suite via `unregister()` : + +```js +class Bidule { + #cleanup = label => { + // ^^^^^−−−−− valeur tenue + console.error(`La méthode \`release\` n'a jamais été appelée pour l'objet avec l'étiquette "${label}"`); + }; + #registry = new FinalizationRegistry(this.#cleanup); + + /** + * Construit une instance `Bidule`. Assurez-vous d'appeler `release` + * lorsque vous avez fini de vous en servir. + * + * @param label Une étiquette pour le `Bidule`. + */ + constructor(label) { + // vvvvv−−−−− valeur tenue + this.#registry.register(this, label, this); + // cible −−−−−^^^^ ^^^^−−−−− jeton de désenregistrement + } + + /** + * Libère les ressources tenues par cette instance de `Bidule` . + */ + release() { + this.#registry.unregister(this); + // ^^^^−−−−− jeton de désenregistrement + } +} +``` + +Dans l'exemple qui suit, on illustre l'enregistrement en utilisant un autre objet comme jeton de désenregistrement : + +```js +class Bidule { + #cleanup = label => { + // ^^^^−−−−− valeur tenue + console.error(`La méthode \`release\` n'a jamais été appelée pour \`Bidule\` pour le fichier "${file.name}"`); + }; + #registry = new FinalizationRegistry(this.#cleanup); + + /** + * Construit une instance de `Bidule` pour le fichier donné. + * Assurez-vous d'appeler `release` lorsque vous n'en avez plus + * besoin. + * @param filename Le nom du fichier. + */ + constructor(filename) { + this.#file = File.open(filename); + // vvvvv−−−−− valeur tenue + this.#registry.register(this, label, this.#file); + // cible −−−−−^^^^ ^^^^^^^^^^−−−−− jeton de désenregistrement + } + + /** + * On libère les ressources tenues par cette instance de `Bidule`. + */ + release() { + if (this.#file) { + this.#registry.unregister(this.#file); + // ^^^^^^^^^^−−−−− jeton de désenregistrement + File.close(this.#file); + this.#file = null; + } + } +} +``` + +## Spécifications + +{{Specifications}} + +## Compatibilité des navigateurs + +{{Compat}} + +## Voir aussi + +- [`FinalizationRegistry`](/fr/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry) -- cgit v1.2.3-54-g00ecf