1. Synchronisation : Mon client (appelant côté C) a une fonction avant la fin de la fonction, j'attends le résultat.
2. Asynchrone : j'appelle une fonction (l'appelant côté C) et je ne connais pas le résultat de la fonction, lorsque la fonction aura le résultat, je serai averti, c'est-à-dire une notification de rappel <.>
3. Blocage : Appelez simplement I (l'appelé du côté s, fonction), je (l'appelé du côté s, la fonction) ne reviendra pas tant que j'aurai complètement accepté les données ou obtenu le résultat. 4. Non bloquant : cela signifie m'appeler (appelé du côté, fonction), je (appelé du côté, fonction) revient immédiatement et informe l'appelant après avoir obtenu le résultatCinq modèles d'E/S
(1) Blocage des E/S (Blocage des E/S) Lorsque l'utilisateur traite Lorsque l'appel système est effectué, le noyau démarre la première étape des E/S et prépare les données dans le tampon. Lorsque les données sont préparées, les données sont copiées du tampon du noyau vers la mémoire du processus utilisateur. l'utilisateur Le processus est libéré de l'état de blocage et s'exécute à nouveau. (2) E/S non bloquantes (E/S non bloquantes) Le processus utilisateur n'est bloqué que dans la deuxième étape, et Il n'y a pas de blocage dans la première étape, mais dans la première étape, le processus utilisateur n'a pas besoin d'attendre aveuglément et interroge constamment le noyau pour voir si les données sont prêtes, ce modèle consomme donc plus de CPU. (3) Multiplexage d'E/S Les deux étapes de l'exécution des E/S sont bloquées par les processus utilisateur, mais les deux étapes sont indépendantes dans un. Après avoir terminé l'opération d'E/S, le processus utilisateur lance deux appels système. La différence avec le blocage des E/S est que le premier segment peut attendre que plusieurs descripteurs soient prêts (4) E/S pilotées par signal (E/S pilotées par signal)Seul le processus utilisateur est bloqué dans la deuxième étape de l'exécution des E/S, mais il n'y a pas de blocage dans la première étape. Dans la première étape de l'exécution des E/S, ce modèle informera activement le processus utilisateur que les données ont été préparées une fois la préparation des données terminée, c'est-à-dire qu'il rappellera le processus utilisateur. Il existe deux types de notifications, l'une est à déclenchement horizontal, c'est-à-dire que les notifications seront envoyées à tout moment si le processus utilisateur ne répond pas, et l'autre est à déclenchement sur front, qui n'est notifié qu'une seule fois. (5) E/S asynchrones (E/S asynchrones) Lorsque le processus utilisateur lance un appel système, il peut immédiatement commencer à faire autre chose Choses, puis jusqu'à ce que les deux étapes de l'exécution des E/S soient terminées, le noyau enverra une notification au processus utilisateur pour indiquer au processus utilisateur que l'opération est terminée.
Technologie de multiplexage d'E/S
select(1).select() fournit une structure de données de fd_set, Chaque élément peut établir une connexion avec un descripteur de fichier ouvert (qu'il s'agisse d'un descripteur de Socket, d'un autre fichier ou d'un canal nommé ou d'un descripteur de périphérique). Le travail d'établissement de la connexion est effectué par le programmeur. Lorsque select() est appelé, le noyau détermine la connexion en fonction du descripteur. IO Le statut modifie le contenu de fd_set, informant ainsi le processus qui a exécuté select() quel Socket ou quel fichier est lisible ou inscriptible. Principalement utilisé pour la communication Socket. (2). Une fois la sélection exécutée, s'il n'y a pas d'entrée de données, le programme attendra (lorsqu'il est bloqué) jusqu'à ce qu'il y ait des données, c'est-à-dire qu'il n'est pas nécessaire de faire des boucles et de dormir dans le programme. . (3). Chaque fois que select est appelé, la collection fd_set doit être copiée du mode utilisateur vers le mode noyau. Cette surcharge sera très importante lorsqu'il y a plusieurs (4). ). Dans le même temps, chaque fois que l'appel de select nécessite que le noyau traverse tous les fd_sets transmis. Cette surcharge est également très importante lorsqu'il existe de nombreux fd_sets(5). est trop petit. La valeur par défaut est 1024poll
(1) L'implémentation de poll est très similaire à select, sauf que la façon de décrire la collection fd_set. est différent. poll utilise la structure de liste chaînée pollfd au lieu de la structure fd_set de select. (2). Pas de limite supérieure sur le nombre de descripteurs de surveillanceepoll/kqueue
(1). nombre de descripteurs de surveillance ;(2). L'efficacité est améliorée, ce n'est pas une méthode d'interrogation, et l'efficacité ne diminuera pas à mesure que le nombre de fd augmente. Seuls les fds actifs et disponibles appelleront la fonction de rappel ; c'est-à-dire que le plus grand avantage de epoll/kqueue est qu'il ne se soucie que de vos connexions "actives" et n'a rien à voir avec le nombre total de connexions, par conséquent, dans le réseau réel. environnement, l'efficacité d'epoll/kqueue sera beaucoup plus élevée que celle de select et poll. (3). Copie de mémoire, utilisant la mémoire de mappage de fichiers mmap() pour accélérer la transmission des messages avec l'espace du noyau ;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!