Heim > Java > javaLernprogramm > Welche Methoden gibt es zum Löschen von Dateien oder Ordnern in Java?

Welche Methoden gibt es zum Löschen von Dateien oder Ordnern in Java?

WBOY
Freigeben: 2023-04-13 17:31:16
nach vorne
5090 Leute haben es durchsucht

    Vier grundlegende Methoden zum Löschen von Dateien oder Ordnern

    Mit den folgenden vier Methoden können alle Dateien oder Ordner gelöscht werden.

    Allen gemeinsam ist:

    Das Löschen schlägt fehl, wenn der Ordner Unterdateien enthält, was bedeutet, dass diese vier Methoden nur leere Ordner löschen können.

    //delete führt den Löschvorgang sofort aus, während deleteOnExit das Programm löscht, wenn es die virtuelle Maschine verlässt.

    delete() der Dateiklasse

    • deleteOnExit() der Dateiklasse: Wenn die virtuelle Maschine beendet wird, löschen Sie die durch das Dateiobjekt dargestellte Datei oder das Verzeichnis, wenn es sich um ein Verzeichnis handelt , es ist erforderlich Stellen Sie sicher, dass das Verzeichnis leer ist, andernfalls kann es nicht gelöscht werden und es gibt keinen Rückgabewert. File类的deleteOnExit():当虚拟机终止时,删除File对象表示的文件或目录,如果表示的是目录,需要保证目录是空的,否则无法删除,无返回值。

    • Files.delete(Path path)

    Files.delete(Path path): Dateien löschen, die sich auf dem als Parameter übergebenen Pfad befinden. Bei anderen Dateisystemvorgängen ist diese Methode möglicherweise nicht atomar. Wenn es sich bei der Datei um einen symbolischen Link handelt, wird der symbolische Link selbst gelöscht und nicht das endgültige Ziel des Links. Wenn es sich bei der Datei um ein Verzeichnis handelt, löscht diese Methode die Datei nur, wenn das Verzeichnis leer ist.

    Files.deleteIfExists(Path path)
    Nach dem Login kopieren

    Es ist zu beachten, dass:

    Die File-Klasse im traditionellen IO und die Path-Klasse in NIO können sowohl Dateien als auch Ordner darstellen. Ein einfacher Vergleich der oben genannten vier Methoden ist nicht leer und führt zu einem Fehler. Traditionelles IO, das ist eine Falle, vermeiden Sie es. Es ist nicht möglich, Void , zu verwenden, aber wenn keine Existenz vorhanden ist, wird der Löschvorgang nicht ausgeführt Files.Delete (PATH PATH) Nio Es wird empfohlen, VoidnosuchFileExceptiondirectemPTYEPTION Files.deleteIfExists(Path path)NIOwahrfalsch DirectoryNotEmptyExceptionFile.delete() vs. Files.delete(Pfadpfad)
    //删除暂存的pdf
    File file =new File(pdfFilename);
    file.delete();
    
    Path path3 = Paths.get(pdfFilename);
    Files.delete(path3);
    Nach dem Login kopieren
    --File.delete()Files.delete(Pfadpfad)
    delete() der Dateiklasse. Traditionelles IO
    zu verwenden
    Unterschied:

    JDK1.0

    Parameter Keine Parameter Datei nicht existKeine Ausnahme auslösen, false zurückgebenJava.nio.file.NoSuchFileException auslösenNicht leeres Verzeichnis löschenLöschen nicht möglich, false zurückgebenLöschen nicht möglich, java.nio.file.DirectoryNotEmptyException auslösenBelegte Dateien löschenLöschen nicht möglich, Rückgabe von falseLöschen nicht möglich, java.nio.file.FileSystemException auslösenDie Datei kann aus anderen Gründen nicht gelöscht werdenKeine Ausnahme auslösen, Rückgabe von falseAuslösen eine bestimmte Unterklasse von java.io.IOException

    如何删除整个目录或者目录中的部分文件

    先造数据

    private  void createMoreFiles() throws IOException {
       Files.createDirectories(Paths.get("D:\data\test1\test2\test3\test4\test5\"));
       Files.write(Paths.get("D:\data\test1\test2\test2.log"), "hello".getBytes());
       Files.write(Paths.get("D:\data\test1\test2\test3\test3.log"), "hello".getBytes());
    }
    Nach dem Login kopieren

    walkFileTree与FileVisitor

    使用walkFileTree方法遍历整个文件目录树,使用FileVisitor处理遍历出来的每一项文件或文件夹

    • FileVisitor的visitFile方法用来处理遍历结果中的“文件”,所以我们可以在这个方法里面删除文件

    • FileVisitor的postVisitDirectory方法,注意方法中的“post”表示“后去做……”的意思,所以用来文件都处理完成之后再去处理文件夹,所以使用这个方法删除文件夹就可以有效避免文件夹内容不为空的异常,因为

    在去删除文件夹之前,该文件夹里面的文件已经被删除了。

    @Test
    void testDeleteFileDir5() throws IOException {
       createMoreFiles();
       Path path = Paths.get("D:\data\test1\test2");
    
       Files.walkFileTree(path,
          new SimpleFileVisitor<Path>() {
             // 先去遍历删除文件
             @Override
             public FileVisitResult visitFile(Path file,
                                      BasicFileAttributes attrs) throws IOException {
                Files.delete(file);
                System.out.printf("文件被删除 : %s%n", file);
                return FileVisitResult.CONTINUE;
             }
             // 再去遍历删除目录
             @Override
             public FileVisitResult postVisitDirectory(Path dir,
                                             IOException exc) throws IOException {
                Files.delete(dir);
                System.out.printf("文件夹被删除: %s%n", dir);
                return FileVisitResult.CONTINUE;
             }
    
          }
       );
    
    }
    Nach dem Login kopieren

    下面的输出体现了文件的删除顺序

    文件被删除 : D:\data\test1\test2\test2.log

    文件被删除 : D:\data\test1\test2\test3\test3.log

    文件夹被删除 : D:\data\test1\test2\test3\test4\test5

    文件夹被删除 : D:\data\test1\test2\test3\test4

    文件夹被删除 : D:\data\test1\test2\test3

    文件夹被删除 : D:\data\test1\test2

    我们既然可以遍历出文件夹或者文件,我们就可以在处理的过程中进行过滤。比如:

    按文件名删除文件或文件夹,参数Path里面含有文件或文件夹名称

    按文件创建时间、修改时间、文件大小等信息去删除文件,参数BasicFileAttributes 里面包含了这些文件信息。

    Files.walk

    如果你对Stream流语法不太熟悉的话,这种方法稍微难理解一点,但是说实话也非常简单。

    使用Files.walk遍历文件夹(包含子文件夹及子其文件),遍历结果是一个Stream

    对每一个遍历出来的结果进行处理,调用Files.delete就可以了。

    @Test
    void testDeleteFileDir6() throws IOException {
       createMoreFiles();
       Path path = Paths.get("D:\data\test1\test2");
    
       try (Stream<Path> walk = Files.walk(path)) {
          walk.sorted(Comparator.reverseOrder())
             .forEach(DeleteFileDir::deleteDirectoryStream);
       }
    
    }
    
    private static void deleteDirectoryStream(Path path) {
       try {
          Files.delete(path);
          System.out.printf("删除文件成功:%s%n",path.toString());
       } catch (IOException e) {
          System.err.printf("无法删除的路径 %s%n%s", path, e);
       }
    }
    Nach dem Login kopieren

    问题:怎么能做到先去删除文件,再去删除文件夹?

    利用的是字符串的排序规则,从字符串排序规则上讲,“D:\data\test1\test2”一定排在“D:\data\test1\test2\test2.log”的前面。

    所以我们使用“sorted(Comparator.reverseOrder())”把Stream顺序颠倒一下,就达到了先删除文件,再删除文件夹的目的。

    下面的输出,是最终执行结果的删除顺序。

    删除文件成功:D:\data\test1\test2\test3\test4\test5

    删除文件成功:D:\data\test1\test2\test3\test4

    删除文件成功:D:\data\test1\test2\test3\test3.log

    删除文件成功:D:\data\test1\test2\test3

    删除文件成功:D:\data\test1\test2\test2.log

    删除文件成功:D:\data\test1\test2

    传统IO-递归遍历删除文件夹

    传统的通过递归去删除文件或文件夹的方法就比较经典了

    //传统IO递归删除
    @Test
    void testDeleteFileDir7() throws IOException {
       createMoreFiles();
       File file = new File("D:\data\test1\test2");
       deleteDirectoryLegacyIO(file);
    
    }
    
    private void deleteDirectoryLegacyIO(File file) {
    
       File[] list = file.listFiles();  //无法做到list多层文件夹数据
       if (list != null) {
          for (File temp : list) {     //先去递归删除子文件夹及子文件
             deleteDirectoryLegacyIO(temp);   //注意这里是递归调用
          }
       }
    
       if (file.delete()) {     //再删除自己本身的文件夹
          System.out.printf("删除成功 : %s%n", file);
       } else {
          System.err.printf("删除失败 : %s%n", file);
       }
    }
    Nach dem Login kopieren

    需要注意的是:

    listFiles()方法只能列出文件夹下面的一层文件或文件夹,不能列出子文件夹及其子文件。

    先去递归删除子文件夹,再去删除文件夹自己本身。

    Das obige ist der detaillierte Inhalt vonWelche Methoden gibt es zum Löschen von Dateien oder Ordnern in Java?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Verwandte Etiketten:
    Quelle:yisu.com
    Erklärung dieser Website
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
    Beliebte Tutorials
    Mehr>
    Neueste Downloads
    Mehr>
    Web-Effekte
    Quellcode der Website
    Website-Materialien
    Frontend-Vorlage