Java NIO - Zbierz

Jak wiemy, Java NIO jest bardziej zoptymalizowanym interfejsem API dla operacji we / wy danych w porównaniu z konwencjonalnym interfejsem API IO języka Java. Jeszcze jednym dodatkowym wsparciem, które zapewnia Java NIO, jest odczyt / zapis danych z / do wielu buforów do kanału. i obsługa zapisu jest określana jako Scatter and Gather, w której dane są rozpraszane do wielu buforów z jednego kanału w przypadku odczytu danych, podczas gdy dane są gromadzone z wielu buforów do jednego kanału w przypadku zapisu danych.

Aby osiągnąć to wielokrotne odczytywanie i zapisywanie z kanału, istnieje ScatteringByteChannel i GatheringByteChannel API, które Java NIO zapewnia do odczytu i zapisu danych, jak pokazano w poniższym przykładzie.

GatheringByteChannel

write to multiple channels - W tym przypadku dokonaliśmy zapisu danych z wielu buforów w jednym kanale, w tym celu przydzielanych jest wiele buforów i dodawanych do tablicy typu bufora, a następnie ta tablica jest przekazywana jako parametr do metody GatheringByteChannel write (), która następnie zapisuje dane z wielu buforów w sekwencji bufory występują w tablicy.Jednym punktem do zapamiętania jest to, że zapisywane są tylko dane między pozycją a granicą buforów.

Poniższy przykład przedstawia sposób zbierania danych w Java NIO

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.GatheringByteChannel;

public class GatherExample {
   private static String FILENAME = "C:/Test/temp.txt";
   public static void main(String[] args) {
      String stream1 = "Gather data stream first";
      String stream2 = "Gather data stream second";
      ByteBuffer bLen1 = ByteBuffer.allocate(1024);
      ByteBuffer bLen2 = ByteBuffer.allocate(1024);
      // Next two buffer hold the data we want to write
      ByteBuffer bstream1 = ByteBuffer.wrap(stream1.getBytes());
      ByteBuffer bstream2 = ByteBuffer.wrap(stream2.getBytes());
      int len1 = stream1.length();
      int len2 = stream2.length();
      // Writing length(data) to the Buffer
      bLen1.asIntBuffer().put(len1);
      bLen2.asIntBuffer().put(len2);
      System.out.println("Gathering : Len1 = " + len1);
      System.out.println("Gathering : Len2 = " + len2);
      // Write data to the file
      try { 
         FileOutputStream out = new FileOutputStream(FILENAME);
         GatheringByteChannel gather = out.getChannel();						
         gather.write(new ByteBuffer[] {bLen1, bLen2, bstream1, bstream2});
         out.close();
         gather.close();
      }
      catch (FileNotFoundException exObj) {
         exObj.printStackTrace();
      }
      catch(IOException ioObj) {
         ioObj.printStackTrace();
      }
   }
}

Wynik

Gathering : Len1 = 24
Gathering : Len2 = 25

Na koniec można stwierdzić, że metoda rozpraszania / zbierania w Java NIO jest wprowadzana jako zoptymalizowana i wielozadaniowa, gdy jest prawidłowo używana.Pozwala delegować do systemu operacyjnego gruntowną pracę polegającą na oddzieleniu danych, które czytasz do wielu wiader lub asemblacji. oddzielne fragmenty danych w całość. bez wątpienia oszczędza to czas i wykorzystuje system operacyjny bardziej efektywnie, unikając kopiowania w buforze, i zmniejsza ilość kodu potrzebnego do napisania i debugowania.