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.
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 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!