Java NIO - Dosya

Java NIO paketi, temelde çoğunlukla Path nesnesi üzerinde çalışan statik yöntemlerini kullanarak dosyaları ve dizinleri işlemek için kullanılan, Dosyalar olarak adlandırılan bir başka yardımcı program API'si sağlar.

Yol eğitiminde belirtildiği gibi, Dosya paketindeki Java 7 sürümü sırasında Java NIO paketinde Yol arayüzünün tanıtıldığı, dolayısıyla bu eğitim aynı Dosya paketi içindir.

Bu sınıf, yalnızca dosyalar, dizinler veya diğer dosya türleri üzerinde çalışan statik yöntemlerden oluşur. Çoğu durumda, burada tanımlanan yöntemler, dosya işlemlerini gerçekleştirmek için ilişkili dosya sistemi sağlayıcısına yetki verir.

Dosyalar sınıfında tanımlanmış ve Java belgelerinden de okunabilen birçok yöntem vardır. Bu eğitimde Java NIO Files sınıfının tüm yöntemleri arasında önemli yöntemlerden bazılarını ele almaya çalıştık.

Dosyalar sınıfının önemli yöntemleri.

Aşağıda Java NIO Files sınıfında tanımlanan önemli yöntemler yer almaktadır.

  • createFile(Path filePath, FileAttribute attrs) - Dosyalar sınıfı, belirtilen Yolu kullanarak dosya oluşturmak için bu yöntemi sağlar.

Misal

package com.java.nio;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
public class CreateFile {
   public static void main(String[] args) {
      //initialize Path object
      Path path = Paths.get("D:file.txt");
      //create file
      try {
         Path createdFilePath = Files.createFile(path);
         System.out.println("Created a file at : "+createdFilePath);
      } 
      catch (IOException e) {
         e.printStackTrace();
      }
   }
}

Çıktı

Created a file at : D:\data\file.txt
  • copy(InputStream in, Path target, CopyOption… options) - Bu yöntem, belirtilen giriş akışındaki tüm baytları belirtilen hedef dosyaya kopyalamak için kullanılır ve uzun değer olarak okunan veya yazılan bayt sayısını döndürür. Aşağıdaki değerlerle bu parametre için LinkOption -

    • COPY_ATTRIBUTES - öznitelikleri yeni dosyaya kopyala, örneğin son değiştirilme zamanı özelliği.

    • REPLACE_EXISTING - varsa, mevcut bir dosyayı değiştirin.

    • NOFOLLOW_LINKS - Bir dosya sembolik bir bağlantıysa, bağlantının hedefi değil, bağın kendisi kopyalanır.

Misal

package com.java.nio;
import java.io.IOException;
import java.nio.charset.Charset;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.StandardCopyOption;
import java.util.List;
public class WriteFile {
   public static void main(String[] args) {
      Path sourceFile = Paths.get("D:file.txt");
      Path targetFile = Paths.get("D:fileCopy.txt");
      try {
         Files.copy(sourceFile, targetFile,
         StandardCopyOption.REPLACE_EXISTING);
      }
      catch (IOException ex) {
         System.err.format("I/O Error when copying file");
      }
      Path wiki_path = Paths.get("D:fileCopy.txt");
      Charset charset = Charset.forName("ISO-8859-1");
      try {
         List<String> lines = Files.readAllLines(wiki_path, charset);
         for (String line : lines) {
            System.out.println(line);
         }
      } 
      catch (IOException e) {
         System.out.println(e);
      }
   }	
}

Çıktı

To be or not to be?
  • createDirectories(Path dir, FileAttribute<?>...attrs) - Bu yöntem, var olmayan tüm ana dizinleri oluşturarak verilen yolu kullanarak dizinler oluşturmak için kullanılır.

  • delete(Path path) - Bu yöntem, dosyayı belirtilen yoldan silmek için kullanılır. Dosya belirtilen yolda yoksa veya dosya dizin ise ve boş olmayabilir ve silinemezse NoSuchFileException atar.

  • exists(Path path) - Bu yöntem, dosyanın belirtilen yolda olup olmadığını kontrol etmek için kullanılır ve dosya mevcutsa doğru veya yanlış döndürür.

  • readAllBytes(Path path) - Bu yöntem, dosyadan belirli bir yoldaki tüm baytları okumak için kullanılır ve dosyadan okunan baytları içeren bayt dizisini döndürür.

Misal

package com.java.nio;
import java.io.IOException;
import java.nio.charset.Charset;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.List;
public class ReadFile {
   public static void main(String[] args) {
      Path wiki_path = Paths.get("D:file.txt");
      Charset charset = Charset.forName("ISO-8859-1");
      try {
         List<String> lines = Files.readAllLines(wiki_path, charset);
         for (String line : lines) {
            System.out.println(line);
         }
      } 
      catch (IOException e) {
         System.out.println(e);
      }
   }	
}

Çıktı

Welcome to file.
  • size(Path path) - Bu yöntem, dosyanın boyutunu bayt cinsinden belirtilen yolda almak için kullanılır.

  • write(Path path, byte[] bytes, OpenOption… options) - Bu yöntem, baytları belirtilen yoldaki bir dosyaya yazmak için kullanılır.

Misal

package com.java.nio;
import java.io.IOException;
import java.nio.charset.Charset;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.List;
public class WriteFile {
   public static void main(String[] args) {
      Path path = Paths.get("D:file.txt");
      String question = "To be or not to be?";
      Charset charset = Charset.forName("ISO-8859-1");
      try {
         Files.write(path, question.getBytes());
         List<String> lines = Files.readAllLines(path, charset);
         for (String line : lines) {
            System.out.println(line);
         }
      } 
      catch (IOException e) {
         System.out.println(e);
      }
   }
}

Çıktı

To be or not to be?