Maison >Java >javaDidacticiel >Java NIO (1) Présentation de Java NIO

Java NIO (1) Présentation de Java NIO

大家讲道理
大家讲道理original
2017-04-11 14:06:081605parcourir

Java NIO est regroupé par les parties principales suivantes :

  • Canaux

  • Tampons

  • Sélecteurs

Bien qu'il existe de nombreuses autres classes et composants dans Java NIO, à mon avis, le canal, le tampon et le sélecteur forment le noyau de l'API. Les 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 démarrent à 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.

À côté de ces classes se trouvent 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 : octet, court , 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