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