Maison  >  Article  >  Java  >  Introduction détaillée à JAVA-1NIO

Introduction détaillée à JAVA-1NIO

零下一度
零下一度original
2017-06-25 10:44:46981parcourir

Présentation de JAVA-1NIO

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 chaînes dans un seul thread :

Pour utiliser le sélecteur, vous devez enregistrer la chaîne auprès du Sélecteur, puis appelez 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.

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