Apakah kaedah untuk memadam fail atau folder dalam Java?
Empat kaedah asas untuk memadam fail atau folder
Empat kaedah berikut semuanya boleh memadamkan fail atau folder.
Persamaan mereka ialah:
Pemadaman akan gagal apabila folder mengandungi subfail, yang bermaksud bahawa empat kaedah ini hanya boleh memadamkan folder kosong.
//delete adalah untuk melakukan pemadaman serta-merta, manakala deleteOnExit adalah untuk memadam program apabila ia keluar dari mesin maya.
delete() kelas Fail
File类的deleteOnExit()
: Apabila mesin maya ditamatkan, padamkan fail atau direktori yang diwakili oleh objek Fail , jika Ia mewakili direktori Anda perlu memastikan bahawa direktori itu kosong, jika tidak, ia tidak boleh dipadamkan dan tiada nilai pulangan.Files.delete(Path path)
: Mengalih keluar fail yang terletak pada laluan yang diluluskan sebagai hujah. Untuk operasi sistem fail lain, kaedah ini mungkin bukan atom. Jika fail adalah pautan simbolik, pautan simbolik itu sendiri akan dipadamkan dan bukannya sasaran akhir pautan itu. Jika fail adalah direktori, kaedah ini hanya memadamkan fail jika direktori itu kosong.
Files.deleteIfExists(Path path)
Perlu diambil perhatian bahawa:
Kelas Fail dalam IO tradisional dan kelas Path dalam NIO boleh mewakili kedua-dua fail dan Boleh mewakili folder.
Perbandingan mudah empat kaedah di atas
- | 说明 | 成功的返回值 | 是否能判别文件夹不存在导致失败 | 是否能判别文件夹不为空导致失败 |
---|---|---|---|---|
File类的delete() | 传统IO | true | 不能(返回false) | 不能(返回false) |
File类的deleteOnExit() | 传统IO,这是个坑,避免使用 | void | 不能,但不存在就不会去执行删除 | 不能(返回void) |
Files.delete(Path path) | NIO,推荐使用 | void | NoSuchFileException | DirectoryNotEmptyException |
Files.deleteIfExists(Path path) | NIO | true | false | DirectoryNotEmptyException |
Perbandingan File.delete() dan Files.delete(Path path)
//删除暂存的pdf File file =new File(pdfFilename); file.delete(); Path path3 = Paths.get(pdfFilename); Files.delete(path3);
Perbezaan:
- | -File.delete() | Files.delete(Path path) |
---|---|---|
JDK | JDK1.0 | JDK1.7 |
来源 | java.io.File对象的实例方法 | java.nio.file.Files类的静态方法 |
参数 | 无参 | java.nio.file.Path |
返回值 | boolean | void |
异常声明 | 无声明 | 声明抛出java.io.IOException |
文件不存在 | 不抛异常,返回false | 抛java.nio.file.NoSuchFileException |
删除非空目录 | 无法删除,返回false | 无法删除,抛java.nio.file.DirectoryNotEmptyException |
删除被占用文件 | 无法删除,返回false | 无法删除,抛java.nio.file.FileSystemException |
其他原因文件无法删除 | 不抛异常,返回false | 抛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()); }
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; } } ); }
下面的输出体现了文件的删除顺序
文件被删除 : 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); } }
问题:怎么能做到先去删除文件,再去删除文件夹?
利用的是字符串的排序规则,从字符串排序规则上讲,“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); } }
需要注意的是:
listFiles()方法只能列出文件夹下面的一层文件或文件夹,不能列出子文件夹及其子文件。
先去递归删除子文件夹,再去删除文件夹自己本身。
Atas ialah kandungan terperinci Apakah kaedah untuk memadam fail atau folder dalam Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Panduan untuk Nombor Smith di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor smith di Jawa? contoh dengan pelaksanaan kod.

Dalam artikel ini, kami telah menyimpan Soalan Temuduga Spring Java yang paling banyak ditanya dengan jawapan terperinci mereka. Supaya anda boleh memecahkan temuduga.

Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah

Panduan untuk TimeStamp to Date di Java. Di sini kita juga membincangkan pengenalan dan cara menukar cap waktu kepada tarikh dalam java bersama-sama dengan contoh.

Kapsul adalah angka geometri tiga dimensi, terdiri daripada silinder dan hemisfera di kedua-dua hujungnya. Jumlah kapsul boleh dikira dengan menambahkan isipadu silinder dan jumlah hemisfera di kedua -dua hujungnya. Tutorial ini akan membincangkan cara mengira jumlah kapsul yang diberikan dalam Java menggunakan kaedah yang berbeza. Formula volum kapsul Formula untuk jumlah kapsul adalah seperti berikut: Kelantangan kapsul = isipadu isipadu silinder Dua jumlah hemisfera dalam, R: Radius hemisfera. H: Ketinggian silinder (tidak termasuk hemisfera). Contoh 1 masukkan Jejari = 5 unit Ketinggian = 10 unit Output Jilid = 1570.8 Unit padu menjelaskan Kirakan kelantangan menggunakan formula: Kelantangan = π × r2 × h (4

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

PHP adalah bahasa skrip yang digunakan secara meluas di sisi pelayan, terutamanya sesuai untuk pembangunan web. 1.PHP boleh membenamkan HTML, memproses permintaan dan respons HTTP, dan menyokong pelbagai pangkalan data. 2.PHP digunakan untuk menjana kandungan web dinamik, data borang proses, pangkalan data akses, dan lain -lain, dengan sokongan komuniti yang kuat dan sumber sumber terbuka. 3. PHP adalah bahasa yang ditafsirkan, dan proses pelaksanaan termasuk analisis leksikal, analisis tatabahasa, penyusunan dan pelaksanaan. 4.Php boleh digabungkan dengan MySQL untuk aplikasi lanjutan seperti sistem pendaftaran pengguna. 5. Apabila debugging php, anda boleh menggunakan fungsi seperti error_reporting () dan var_dump (). 6. Mengoptimumkan kod PHP untuk menggunakan mekanisme caching, mengoptimumkan pertanyaan pangkalan data dan menggunakan fungsi terbina dalam. 7

Java ialah bahasa pengaturcaraan popular yang boleh dipelajari oleh pembangun pemula dan berpengalaman. Tutorial ini bermula dengan konsep asas dan diteruskan melalui topik lanjutan. Selepas memasang Kit Pembangunan Java, anda boleh berlatih pengaturcaraan dengan mencipta program "Hello, World!" Selepas anda memahami kod, gunakan gesaan arahan untuk menyusun dan menjalankan program, dan "Hello, World!" Pembelajaran Java memulakan perjalanan pengaturcaraan anda, dan apabila penguasaan anda semakin mendalam, anda boleh mencipta aplikasi yang lebih kompleks.
