


Parlons à nouveau de la programmation asynchrone JavaScript_compétences Javascript
Avec le développement du front-end, le mot asynchrone devient de plus en plus courant. Supposons que nous ayons maintenant une telle tâche asynchrone :
Initiez plusieurs requêtes au serveur, et les résultats de chaque requête sont utilisés comme paramètres pour la requête suivante.
Jetons un coup d'œil à ce que nous devons faire :
Rappels
La première chose qui nous vient à l’esprit et la plus couramment utilisée est la fonction de rappel. Faisons une simple encapsulation :
let makeAjaxCall = (url, cb) => { // do some ajax // callback with result } makeAjaxCall('http://url1', (result) => { result = JSON.parse(result) })
Hmm, ça a l'air plutôt bien ! Mais lorsque l'on essaie d'imbriquer plusieurs tâches, le code ressemble à ceci :
makeAjaxCall('http://url1', (result) => { result = JSON.parse(result) makeAjaxCall(`http://url2?q=${result.query}`, (result) => { result = JSON.parse(result) makeAjaxCall(`http://url3?q=${result.query}`, (result) => { // ... }) }) })
Oh mon Dieu ! Laissez ce tas }) aller au diable !
Nous voulons donc essayer d'utiliser le Modèle d'événement JavaScript :
1. Pub/Sub
Dans le traitement des événements DOM, Pub/Sub est un mécanisme très courant. Par exemple, nous devons ajouter une surveillance des événements aux éléments :
.elem.addEventListener(type, (evt) => { // handler })
Alors pouvons-nous construire un modèle similaire pour gérer les tâches asynchrones ?
La première chose est de construire un centre de distribution et d'ajouter la méthode on/emit :
let PubSub = { events: {}, on(type, handler) { let events = this.events events[type] = events[type] || [] events[type].push(handler) }, emit(type, ...datas) { let events = this.events if (!events[type]) { return } events[type].forEach((handler) => handler(...datas)) } }
Ensuite, nous pouvons l'utiliser comme ceci :
const urls = [ 'http://url1', 'http://url2', 'http://url3' ] let makeAjaxCall = (url) => { // do some ajax PubSub.emit('ajaxEnd', result) } let subscribe = (urls) => { let index = 0 PubSub.on('ajaxEnd', (result) => { result = JSON.parse(result) if (urls[++index]) { makeAjaxCall(`${urls[index]}?q=${result.query}`) } }) makeAjaxCall(urls[0]) }
Il ne semble pas y avoir de changement révolutionnaire par rapport à la fonction de rappel, mais l'avantage de celle-ci est que l'on peut mettre les fonctions de requête et de traitement dans des modules différents pour réduire le couplage.
2. Promesse
Le véritable changement révolutionnaire est la spécification Promise. Avec Promise, nous pouvons effectuer des tâches asynchrones comme celle-ci :
let makeAjaxCall = (url) => { return new Promise((resolve, reject) => { // do some ajax resolve(result) }) } makeAjaxCall('http://url1') .then(JSON.parse) .then((result) => makeAjaxCall(`http://url2?q=${result.query}`)) .then(JSON.parse) .then((result) => makeAjaxCall(`http://url3?q=${result.query}`))
Super ! C'est écrit comme une fonction synchrone !
Ne vous inquiétez pas, jeune homme. Nous avons encore mieux :
3. Générateurs
Un autre grand tueur d'ES6 est les générateurs[2]. Dans une fonction génératrice, nous pouvons interrompre l'exécution de la fonction via l'instruction rendement et parcourir les instructions via la méthode suivante en dehors de la fonction. Plus important encore, nous pouvons injecter des données dans la fonction via la méthode suivante pour modifier dynamiquement le comportement de la fonction. fonction. Par exemple :
function* gen() { let a = yield 1 let b = yield a * 2 return b } let it = gen() it.next() // output: {value: 1, done: false} it.next(10) // a = 10, output: {value: 20, done: false} it.next(100) // b = 100, output: {value: 100, done: true}
Encapsulez notre précédente fonction makeAjaxCall via un générateur :
let makeAjaxCall = (url) => { // do some ajax iterator.next(result) } function* requests() { let result = yield makeAjaxCall('http://url1') result = JSON.parse(result) result = yield makeAjaxCall(`http://url2?q=${result.query}`) result = JSON.parse(result) result = yield makeAjaxCall(`http://url3?q=${result.query}`) } let iterator = requests() iterator.next() // get everything start
Oh ! La logique semble très claire, mais c'est tellement inconfortable de devoir injecter l'itérateur de l'extérieur à chaque fois...
Ne vous inquiétez pas, mélangeons Promise et Generator et voyons quelle magie noire sera produite :
let makeAjaxCall = (url) => { return new Promise((resolve, reject) => { // do some ajax resolve(result) }) } let runGen = (gen) => { let it = gen() let continuer = (value, err) => { let ret try { ret = err ? it.throw(err) : it.next(value) } catch (e) { return Promise.reject(e) } if (ret.done) { return ret.value } return Promise .resolve(ret.value) .then(continuer) .catch((e) => continuer(null, e)) } return continuer() } function* requests() { let result = yield makeAjaxCall('http://url1') result = JSON.parse(result) result = yield makeAjaxCall(`http://url2?q=${result.query}`) result = JSON.parse(result) result = yield makeAjaxCall(`http://url3?q=${result.query}`) } runGen(requests)
La fonction runGen ressemble à un automate, tellement génial !
En fait, cette méthode runGen est une implémentation de la fonction asynchrone ECMAScript 7 :
4. Fonction asynchrone
Dans ES7, une fonction asynchrone plus naturelle[3] est introduite. En utilisant la fonction asynchrone, nous pouvons terminer la tâche comme ceci :
let makeAjaxCall = (url) => { return new Promise((resolve, reject) => { // do some ajax resolve(result) }) } ;(async () => { let result = await makeAjaxCall('http://url1') result = JSON.parse(result) result = await makeAjaxCall(`http://url2?q=${result.query}`) result = JSON.parse(result) result = await makeAjaxCall(`http://url3?q=${result.query}`) })()
Tout comme lorsque nous avons combiné Promise et Generator ci-dessus, le mot-clé wait accepte également une promesse. Dans la fonction asynchrone, les instructions restantes ne seront exécutées qu'une fois l'instruction terminée après wait. L'ensemble du processus est exactement comme si nous utilisions la fonction runGen pour encapsuler le générateur.
Ci-dessus sont plusieurs modes de programmation asynchrone JavaScript résumés dans cet article. J'espère que cela sera utile à l'apprentissage de chacun.

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Résumé : La programmation asynchrone en C++ permet d'effectuer plusieurs tâches sans attendre des opérations fastidieuses. Utilisez des pointeurs de fonction pour créer des pointeurs vers des fonctions. La fonction de rappel est appelée lorsque l'opération asynchrone est terminée. Les bibliothèques telles que boost::asio fournissent un support de programmation asynchrone. Le cas pratique montre comment utiliser les pointeurs de fonction et boost::asio pour implémenter des requêtes réseau asynchrones.

Tutoriel JavaScript : Comment obtenir le code d'état HTTP, des exemples de code spécifiques sont requis Préface : Dans le développement Web, l'interaction des données avec le serveur est souvent impliquée. Lors de la communication avec le serveur, nous devons souvent obtenir le code d'état HTTP renvoyé pour déterminer si l'opération a réussi et effectuer le traitement correspondant en fonction de différents codes d'état. Cet article vous apprendra comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournira quelques exemples de codes pratiques. Utilisation de XMLHttpRequest

3 problèmes et solutions courants dans la programmation asynchrone dans les frameworks Java : Callback Hell : utilisez Promise ou CompletableFuture pour gérer les rappels dans un style plus intuitif. Conflit de ressources : utilisez des primitives de synchronisation (telles que des verrous) pour protéger les ressources partagées et envisagez d'utiliser des collections thread-safe (telles que ConcurrentHashMap). Exceptions non gérées : gérez explicitement les exceptions dans les tâches et utilisez un cadre de gestion des exceptions (tel que CompletableFuture.exceptionally()) pour gérer les exceptions.

Le framework Go utilise les fonctionnalités de concurrence et asynchrones de Go pour fournir un mécanisme permettant de gérer efficacement les tâches simultanées et asynchrones : 1. La concurrence est obtenue via Goroutine, permettant d'exécuter plusieurs tâches en même temps. 2. La programmation asynchrone est implémentée via des canaux, qui peut être exécuté sans bloquer le thread principal;3. Convient aux scénarios pratiques, tels que le traitement simultané des requêtes HTTP, l'acquisition asynchrone des données de base de données, etc.

Introduction à la méthode d'obtention du code d'état HTTP en JavaScript : Dans le développement front-end, nous devons souvent gérer l'interaction avec l'interface back-end, et le code d'état HTTP en est une partie très importante. Comprendre et obtenir les codes d'état HTTP nous aide à mieux gérer les données renvoyées par l'interface. Cet article explique comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournit des exemples de code spécifiques. 1. Qu'est-ce que le code d'état HTTP ? Le code d'état HTTP signifie que lorsque le navigateur lance une requête au serveur, le service

1. Pourquoi utiliser la programmation asynchrone ? La programmation traditionnelle utilise le blocage des E/S, ce qui signifie que le programme attend la fin d'une opération avant de continuer. Cela peut bien fonctionner pour une seule tâche, mais peut entraîner un ralentissement du programme lors du traitement d'un grand nombre de tâches. La programmation asynchrone brise les limitations des E/S bloquantes traditionnelles et utilise des E/S non bloquantes, ce qui signifie que le programme peut distribuer des tâches à différents threads ou boucles d'événements pour exécution sans attendre la fin de la tâche. Cela permet au programme de gérer plusieurs tâches simultanément, améliorant ainsi ses performances et son efficacité. 2. La base de la programmation asynchrone Python La base de la programmation asynchrone Python est constituée de coroutines et de boucles d'événements. Les coroutines sont des fonctions qui permettent à une fonction de basculer entre la suspension et la reprise. La boucle événementielle est responsable de la planification

Les avantages de la programmation asynchrone en PHP incluent un débit plus élevé, une latence plus faible, une meilleure utilisation des ressources et une évolutivité. Les inconvénients incluent la complexité, la difficulté de débogage et la prise en charge limitée des bibliothèques. Dans le cas réel, ReactPHP est utilisé pour gérer les connexions WebSocket, démontrant l'application pratique de la programmation asynchrone.

Avantages : Amélioration des performances : exécution de tâches parallèles, utilisant pleinement les processeurs multicœurs. Évolutivité : évoluez facilement pour gérer des charges de travail plus importantes. Réactivité : le thread principal ne bloque pas, ce qui permet à l'application de rester réactive. Optimisation des ressources : évitez le besoin de structures de verrouillage et de synchronisation. Défi : Complexité du code : Gestion de plusieurs tâches indépendantes. Difficulté de débogage : les tâches sont exécutées dans différents threads ou coroutines. Gestion des erreurs : la gestion des erreurs dans un environnement simultané est complexe et nécessite des mesures supplémentaires. Cas pratique : télécharger des fichiers en parallèle, utiliser Goroutine pour télécharger plusieurs fichiers en même temps, montrant comment la programmation asynchrone peut améliorer les performances.
