本文是Java IO總結系列篇的第3篇,前篇的訪問地址如下:
本文為大家介紹Java IO-創建文件夾的四種方法,及其優缺點的解析。如果您閱讀完成,覺得此文對您有幫助,請給我點個贊,您的支持是我不竭的創作動力。
1.傳統API創建文件夾方式
Java傳統的IO API種使用java.io.File
類中的file.mkdir()
和file.mkdirs()
方法創建文件夾
file.mkdir()
創建文件夾成功返回true,失敗返回false。如果被創建文件夾的父文件夾不存在也返回false.沒有異常拋出。file.mkdirs()
創建文件夾連同該文件夾的父文件夾,如果創建成功返回true,創建失敗返回false。創建失敗同樣沒有異常拋出。
@Test
void testCreateDir1() {
//“D:\data111”目錄現在不存在
String dirStr = "D:\\data111\\test";
File directory = new File(dirStr);
//mkdir
boolean hasSucceeded = directory.mkdir();
System.out.println("創建文件夾結果(不含父文件夾):" + hasSucceeded);
//mkdirs
hasSucceeded = directory.mkdirs();
System.out.println("創建文件夾結果(包含父文件夾):" + hasSucceeded);
}
輸出結果如下:使用mkdir創建失敗,使用mkdirs創建成功。
創建文件夾結果(不含父文件夾):false
創建文件夾結果(包含父文件夾):true
大家可以看到,mkdir和mkdirs雖然可以創建文件,但是它們在異常處理的環節做的非常不友好。創建失敗之后統一返回false,創建失敗的原因沒有說明。是父文件夾不存在所以創建失敗?還是文件夾已經存在所以創建失敗?還是因為磁盤IO原因導致創建文件夾失敗?
2. Java NIO創建文件夾
為了解決傳統IO創建文件夾中異常失敗處理問題不明確的問題,在Java的NIO中進行了改進。
2.1. Files.createDirectory
創建文件夾
- 如果被創建文件夾的父文件夾不存在,則拋出
NoSuchFileException
. - 如果被創建的文件夾已經存在,則拋出
FileAlreadyExistsException
. - 如果因為磁盤IO出現異常,則拋出
IOException
.
Path path = Paths.get("D:\\data222\\test");
Path pathCreate = Files.createDirectory(path);
2.2.Files.createDirectories
創建文件夾及其父文件夾
- 如果被創建文件夾的父文件夾不存在,就創建它
- 如果被創建的文件夾已經存在,就是用已經存在的文件夾,不會重復創建,沒有異常拋出
- 如果因為磁盤IO出現異常,則拋出
IOException
.
Path path = Paths.get("D:\\data222\\test");
Path pathCreate = Files.createDirectorys(path);
另外大家要注意:NIO的API創建的文件夾返回值是Path,這樣方便我們在創建完成文件夾之后繼續向文件夾里面寫入文件數據等操作。比傳統IO只返回一個boolean值要好得多。
歡迎關注我的博客,里面有很多精品合集
- 本文轉載注明出處(必須帶連接,不能只轉文字):字母哥博客。
覺得對您有幫助的話,幫我點贊、分享!您的支持是我不竭的創作動力! 。另外,筆者最近一段時間輸出了如下的精品內容,期待您的關注。