


Publication d'une bibliothèque pour l'exécution synchrone de processus asynchrones dans JS/TS
J'ai publié une bibliothèque appelée sync-actions qui permet aux processus asynchrones d'être exécutés de manière synchrone en JavaScript/TypeScript. Surtout dans TypeScript, vous pouvez appeler des fonctions définies de manière sécurisée. Il est destiné à être utilisé dans les cas où vous souhaitez exécuter des processus asynchrones au sein de fonctions que vous ne voulez pas (ou ne pouvez pas) marquer comme asynchrones.
Caractéristiques
- Utilise Node.js worker_threads
- Les processus asynchrones sont exécutés dans un sous-thread et le thread principal attend de manière synchrone leur achèvement.
- Appels de fonction de type sécurisé
- Dans TypeScript, vous pouvez utiliser les informations de type des fonctions définies.
- Publié en tant qu'ESM natif
- C'est simplifié en ne prenant pas en charge CommonJS.
Dépôt
https://github.com/koyopro/sync-actions
Usage
Installation
Il est publié sous forme de package npm, veuillez donc l'installer à l'aide de npm install ou similaire.
npm install sync-actions
Utilisation de base
En passant une fonction asynchrone qui renvoie un objet Promise à definitionSyncWorker(), vous pouvez définir l'interface et démarrer le thread de travail avec launch(). On suppose que le fichier définissant le travailleur est créé séparément des autres fichiers de traitement.
// worker.js import { defineSyncWorker } from "sync-actions"; export const { actions, worker } = defineSyncWorker(import.meta.filename, { ping: async () => { // Execute asynchronous process, await new Promise((resolve) => setTimeout(resolve, 1000)); // Return the result as a return value return "pong"; } }).launch();
// main.js import { actions, worker } from "./worker.js"; // You can execute asynchronous functions synchronously console.log(actions.ping()); // => "pong" is output after 1 second worker.terminate();
Appels de fonction de type sécurisé
Dans TypeScript, vous pouvez appeler les fonctions définies avec définirSyncWorker de manière sécurisée.
// worker.ts import { defineSyncWorker } from "sync-actions"; export const { actions, worker } = defineSyncWorker(import.meta.filename, { // By specifying the types of arguments and return values, type-safe calls are possible add: async (a: number, b: number): Promise<number> => { return a + b; } }).launch(); </number>
// main.ts import { actions, worker } from "./worker.js"; // Type-safe call actions.add(1, 2); // => 3 (number) // @ts-expect-error actions.add("1", 2); // => Argument of type 'string' is not assignable to parameter of type 'number' worker.terminate();
Arrière-plan
Le contenu jusqu'à présent est le même que celui du README, je vais donc décrire le contexte de sa création.
Je développe un ORM appelé Accel Record.1 Contrairement aux ORM généraux, Accel Record est conçu pour effectuer un accès à la base de données avec une interface synchrone.2 La partie qui exécute l'accès à la base de données de manière synchrone. a été réalisé en exécutant des processus asynchrones dans un sous-processus démarré avec le module child_process.3 Je pensais qu'en utilisant work_threads au lieu de child_process, je pourrais réduire la surcharge au moment de l'exécution.
Accel Record est également conçu pour être similaire à Active Record de Ruby on Rails en termes de convivialité, et l'une des choses que je souhaite réaliser à l'avenir est de créer une bibliothèque comme CarrierWave. CarrierWave vous permet d'enregistrer des images sur des services de stockage externes (tels qu'AWS S3) lors de l'enregistrement d'enregistrements, et pour y parvenir avec Accel Record, il est nécessaire d'exécuter des processus asynchrones tels que le téléchargement d'images de manière synchrone. Je m'attends à ce que ce processus puisse être exécuté plus rapidement en utilisant work_threads au lieu de sous-processus.
J'ai donc cherché une fois une bibliothèque qui exécute de manière synchrone des processus asynchrones à l'aide de worker_threads. J'ai trouvé plusieurs bibliothèques telles que synckit et deasync, mais aucune d'entre elles n'a fonctionné comme prévu de mon côté, j'ai donc décidé de créer la mienne. Depuis que j'y étais, j'ai pensé créer une interface pouvant être utilisée de manière sécurisée avec TypeScript.
Plus de détails internes
- Jusqu'à ce que le processus asynchrone dans le sous-thread démarré avec worker_threads soit terminé, le thread principal est bloqué à l'aide d'Atomic.wait().
- MessageChannel est utilisé pour la communication entre les threads. Le code source de synckit a été très utile pour cette partie de l'implémentation.
- Lors du démarrage d'un Worker avec worker_threads, il est nécessaire de transpiler le fichier .ts en .js. Pour cette partie, j'utilise esbuild.
- Lors du démarrage d'un Worker, je voulais transmettre le code source transpilé sous forme de chaîne au Worker pour exécution, mais cela ne fonctionnait pas correctement dans mon environnement. C’est la partie où j’ai le plus eu du mal. En fin de compte, j'ai écrit le fichier sous node_modules et transmis son chemin au Worker. Cette méthode s'est avérée la plus stable.
-
Introduction à "Accel Record" : un ORM TypeScript utilisant le modèle d'enregistrement actif ↩
-
Pourquoi nous avons adopté une API synchrone pour le nouvel ORM TypeScript ↩
-
Techniques d'accès synchrone à la base de données dans TypeScript ↩
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Que ce soit pour choisir Python ou JavaScript dépend du type de projet: 1) Choisissez Python pour les tâches de science et d'automatisation des données; 2) Choisissez JavaScript pour le développement frontal et complet. Python est favorisé pour sa bibliothèque puissante dans le traitement et l'automatisation des données, tandis que JavaScript est indispensable pour ses avantages dans l'interaction Web et le développement complet.

Python et JavaScript ont chacun leurs propres avantages, et le choix dépend des besoins du projet et des préférences personnelles. 1. Python est facile à apprendre, avec une syntaxe concise, adaptée à la science des données et au développement back-end, mais a une vitesse d'exécution lente. 2. JavaScript est partout dans le développement frontal et possède de fortes capacités de programmation asynchrones. Node.js le rend adapté au développement complet, mais la syntaxe peut être complexe et sujet aux erreurs.

Javascriptisnotbuiltoncorc; il est en interprétéLanguageThatrunSoninesoftenwritteninc .1) javascriptwasdesignedasalightweight, interprété de LanguageForwebbrowsers.2) EnginesevolvedFromSimpleInterpreterstoJitCompilers, typicalinc, impropringperformance.

JavaScript peut être utilisé pour le développement frontal et back-end. L'endouage frontal améliore l'expérience utilisateur via les opérations DOM, et le back-end gère les tâches du serveur via Node.js. 1. Exemple frontal: modifiez le contenu du texte de la page Web. 2. Exemple backend: Créez un serveur Node.js.

Le choix de Python ou JavaScript doit être basé sur le développement de carrière, la courbe d'apprentissage et l'écosystème: 1) le développement de carrière: Python convient à la science des données et au développement de back-end, tandis que JavaScript convient au développement frontal et complet. 2) Courbe d'apprentissage: la syntaxe Python est concise et adaptée aux débutants; La syntaxe JavaScript est flexible. 3) Ecosystème: Python possède de riches bibliothèques informatiques scientifiques, et JavaScript a un puissant cadre frontal.

La puissance du cadre JavaScript réside dans la simplification du développement, l'amélioration de l'expérience utilisateur et les performances des applications. Lorsque vous choisissez un cadre, considérez: 1. Taille et complexité du projet, 2. Expérience d'équipe, 3. Écosystème et soutien communautaire.

INTRODUCTION Je sais que vous pouvez le trouver étrange, que doit faire exactement JavaScript, C et Browser? Ils semblent sans rapport, mais en fait, ils jouent un rôle très important dans le développement Web moderne. Aujourd'hui, nous discuterons du lien étroit entre ces trois. Grâce à cet article, vous apprendrez comment JavaScript fonctionne dans le navigateur, le rôle de C dans le moteur du navigateur et comment ils fonctionnent ensemble pour stimuler le rendu et l'interaction des pages Web. Nous connaissons tous la relation entre JavaScript et Browser. JavaScript est la langue principale du développement frontal. Il fonctionne directement dans le navigateur, rendant les pages Web vives et intéressantes. Vous êtes-vous déjà demandé pourquoi javascr

Node.js excelle dans des E / S efficaces, en grande partie grâce aux flux. Streams traite les données progressivement, en évitant la surcharge de mémoire - idéal pour les fichiers volumineux, les tâches réseau et les applications en temps réel. Combiner les flux avec la sécurité de type dactylographié crée un powe


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

Dreamweaver CS6
Outils de développement Web visuel

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

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

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.
