Maison  >  Article  >  Java  >  Tutoriel 1 de la série Java NIO : une brève introduction à Java NIO

Tutoriel 1 de la série Java NIO : une brève introduction à Java NIO

php是最好的语言
php是最好的语言original
2018-07-30 10:39:471847parcourir

Java NIO se compose des parties principales suivantes :

  • Canaux

  • Tampons

  • Sélecteurs

Bien qu'il existe de nombreuses autres classes et composants dans Java NIO, à mon avis, Channel, Buffer et Selector constituent l'API de base. D'autres composants, tels que Pipe et FileLock, ne sont que des classes utilitaires utilisées avec les trois composants principaux. Par conséquent, dans cet aperçu, je me concentrerai sur ces trois composants. D'autres composants sont traités dans des chapitres distincts.

Canal et tampon

Fondamentalement, toutes les E/S commencent à partir d'un canal dans NIO. Les chaînes sont un peu comme les flux. Les données peuvent être lues du canal vers le tampon, ou écrites du tampon vers le canal. Voici une illustration :

Il existe plusieurs types de Channel et de Buffer. Voici les implémentations de certains canaux majeurs dans JAVA NIO :

  • FileChannel

  • DatagramChannel

  • SocketChannel

  • ServerSocketChannel

Comme vous pouvez le constater, ces canaux couvrent les IO réseau UDP et TCP, ainsi que les IO fichiers.

En plus de ces classes, il existe des interfaces intéressantes, mais par souci de simplicité, j'ai essayé de ne pas les mentionner dans l'aperçu. Je les expliquerai dans d'autres chapitres de ce tutoriel où ils sont pertinents.

Voici les principales implémentations de Buffer dans Java NIO :

  • ByteBuffer

  • CharBuffer

  • DoubleBuffer

  • FloatBuffer

  • IntBuffer

  • LongBuffer

  • ShortBuffer

Ces tampons couvrent les types de données de base que vous pouvez envoyer via IO : byte, short, int, long, float, double et char.

Java NIO possède également un MappedByteBuffer, qui est utilisé pour représenter les fichiers mappés en mémoire. Je ne vais pas l'expliquer dans la présentation.

Selector

Selector permet à un seul thread de traiter plusieurs canaux. Si votre application ouvre plusieurs connexions (canaux), mais que le trafic de chaque connexion est très faible, l'utilisation de Selector peut s'avérer pratique. Par exemple, dans un serveur de chat.

Voici une illustration de l'utilisation d'un sélecteur pour traiter 3 canaux dans un seul thread :

Pour utiliser Selector, vous devez vous inscrire auprès de Selector Channel, puis appelle sa méthode select(). Cette méthode sera bloquée jusqu'à ce qu'une chaîne enregistrée ait un événement prêt. Une fois cette méthode renvoyée, le thread peut gérer ces événements. Des exemples d'événements incluent l'arrivée de nouvelles connexions, la réception de données, etc.

Articles connexes :

Tutoriel 2 de la série Java NIO : flux de type canal Java NIO

Tutoriel Java NIO Series 3 : Utilisation de base de Buffer

Vidéos associées :

Illustration du processus de téléchargement JDK - Tutoriel vidéo d'introduction à l'élémentaire JAVA

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn