Java文件管理操作的知識點整理
一.基本文件操作
獲取及判斷文件屬性
代碼示例如下:
import java.io.IOException;
public class test {
public static void main(String[] args) throws IOException {
File file = new File("./test.txt");
System.out.println(file.getParent());
System.out.println(file.getName());
System.out.println(file.getPath());
System.out.println(file.getAbsolutePath());
System.out.println(file.getCanonicalPath());
//創(chuàng)建文件前
System.out.println(file.exists());
System.out.println(file.isDirectory());
System.out.println(file.isFile());
System.out.println("---------------");
//創(chuàng)建文件后
file.createNewFile();
System.out.println(file.exists());
System.out.println(file.isDirectory());
System.out.println(file.isFile());
//刪除文件
System.out.println("--------------");
file.delete();
System.out.println(file.exists());
}
}
getParent():獲取上級目錄,若無指定則返回null
getName():獲取當(dāng)前文件名
getPath():獲取以工作目錄為基準(zhǔn)的相對路徑
getAbsolutePath():獲取以盤頭為起始點的絕對路徑
getCanonicalPath():同上,但是會進(jìn)行一些精簡
exists():判斷文件是否存在
isDirectory():判斷文件是否是目錄
isFile():判斷文件是否是文件
delete():刪除文件
上述代碼的運(yùn)行結(jié)果如下:

創(chuàng)建及修改文件
import java.io.File;
import java.io.IOException;
public class test {
public static void main(String[] args) throws IOException {
File file = new File("./test.txt");
file.createNewFile();
//退出時刪除
file.deleteOnExit();
System.out.println(file.exists());
}
}
deleteOnExit():退出時刪除
createNewFile():創(chuàng)建對應(yīng)文件
public class test {
public static void main(String[] args) throws IOException {
File file = new File("./test");
//創(chuàng)建單級目錄
file.mkdir();
//創(chuàng)建多級目錄
File file1 = new File("test1/a/11");
file1.mkdirs();
}
}
上述代碼運(yùn)行結(jié)果如下:

mkdir():根據(jù)路徑創(chuàng)建單級目錄
mkdirs():根據(jù)路徑創(chuàng)建多級目錄
public class test {
public static void main(String[] args) throws IOException {
File file1 = new File("test");
File file2 = new File("test1");
//重命名
file1.renameTo(file2);
}
}
renameTo():將一個文件的名字賦值給另一個文件
二.文件讀寫
讀文件
字節(jié)流
我們事先準(zhǔn)備一個test.txt文件,里面包含內(nèi)容"Hello".
public class test {
public static void main(String[] args) throws IOException {
File file = new File("text1.txt");
file.createNewFile();
//打開文件
InputStream inputStream = new FileInputStream("text1.txt");
//讀文件
while(true){
int b = inputStream.read();
if(b == -1){
break;
}
System.out.println(b);
}
//關(guān)閉文件
inputStream.close();
}
}實際上,read()有很多個版本,具體如下:

上述代碼中使用的是第一個版本,一次讀取一個字節(jié),并將這個字節(jié)的內(nèi)容作為返回值返回,如果讀取到文件結(jié)束符(EOF),則返回-1.
第二個版本要求一個"輸出型參數(shù)"---一個字節(jié)數(shù)組.read()會從文件里把內(nèi)容全部讀入該字節(jié)數(shù)組中,若溢出則截斷.
第三個版本與第二個版本相似,只不過允許通過參數(shù)控制數(shù)據(jù)的傳入起點和終點(也即允許傳入的數(shù)據(jù)長度).
上述代碼的運(yùn)行結(jié)果如下:

可見讀取的是"Hello"每個字符對應(yīng)的ASCII碼值.
這樣可讀性無疑是很低的,我們可以將其轉(zhuǎn)為字符串的形式輸出,代碼示例如下:
public class test {
public static void main(String[] args) throws IOException {
File file = new File("text1.txt");
file.createNewFile();
//打開文件
InputStream inputStream = new FileInputStream("text1.txt");
//讀文件
byte[] b = new byte[1024];
int len = inputStream.read(b);
String s = new String(b,0,len,"utf8");
System.out.println(s);
//關(guān)閉文件
inputStream.close();
}
}我們可以通過讀出來的字節(jié)數(shù)組,反向構(gòu)造出其原本的字符串,這樣就能得到"Hello"了,但這樣無疑很麻煩.因此,對于這種非二進(jìn)制的數(shù)組,我們可以使用字符流.
字符流
字符流對應(yīng)著Reader和FileReader兩個關(guān)鍵字.
public class test {
public static void main(String[] args) throws IOException {
File file = new File("text1.txt");
file.createNewFile();
//打開文件
Reader reader = new FileReader("text1.txt");
char[] buffer = new char[1024];
int len = reader.read(buffer);
for (int i = 0; i < len; i++) {
System.out.print(buffer[i]);
}
reader.close();
}
}這樣輸出出來的直接就是"Hello",而不是ASCII碼值.
其他要點
1.InputStream和Reader兩個都是抽象類,沒辦法直接實例化.因此我們需要借助他們的子類FileInputStream和FileReader來實例化.
2.我們創(chuàng)建的文件都在硬盤上,直接操作的話比較困難.因此我們嘗試在內(nèi)存上創(chuàng)建一個媒介,間接的操作硬盤上的文件.我們將InputStream和Reader這種媒介成為句柄(Handler).
3.上述代碼的寫法實際上是不嚴(yán)謹(jǐn)?shù)?因為一旦程序在運(yùn)行途中拋出了異常,代碼末尾的close()就無法執(zhí)行.因此我們應(yīng)該把close()放在finally下.保證在文件描述符表上的資源得以釋放.
4.關(guān)于文件描述符表:文件描述符表可以簡單理解成PCB中的一個數(shù)組/順序表.數(shù)組中的每個元素都對應(yīng)著當(dāng)前進(jìn)程打開的文件.這個數(shù)組的下標(biāo),就稱為"文件描述符".每當(dāng)我們打開一個文件時,就會在文件描述符表中占據(jù)一個位置;每次關(guān)閉文件,都會釋放一個位置.然而文件描述表的長度是存在上限的,如果在進(jìn)程中一直打開文件而不釋放,這就會導(dǎo)致進(jìn)程在后續(xù)打開文件的時候拋出異常.
5.實際上,我們有一套更實用的方法從文件中讀取內(nèi)容,代碼示例如下:
public class test {
public static void main(String[] args) throws IOException {
File file = new File("text1.txt");
file.createNewFile();
InputStream inputStream = new FileInputStream("text1.txt");
Scanner scanner = new Scanner(inputStream);
String s = scanner.next();
System.out.println(s);
}
}
我們可以將InputStream作為Scanner構(gòu)造函數(shù)的參數(shù),這樣我們就可以使用Scanner靈活讀取文件內(nèi)部的內(nèi)容.
寫文件
字節(jié)流
對于字節(jié)流的輸入方式,我們有OutputStream和FileOutputStream這一套組合.
public class test {
public static void main(String[] args) throws IOException {
File file = new File("text1.txt");
file.createNewFile();
try(OutputStream outputStream = new FileOutputStream("text1.txt")){
outputStream.write('h');
outputStream.write('e');
outputStream.write('l');
outputStream.write('l');
outputStream.write('o');
}catch(IOException e){
e.printStackTrace();
}
}
}字符流
對于字符流的輸入方式,我們有Writer和FileWriter這一套組合.
public class test {
public static void main(String[] args) throws IOException {
File file = new File("text1.txt");
file.createNewFile();
try(Writer writer = new FileWriter("text1.txt")){
writer.write("hello");
}catch(IOException e){
e.printStackTrace();
}
}
}
字節(jié)流封裝
與讀取文件內(nèi)容部分一樣,我們可以將字節(jié)流封裝,其可以靈活的向文件內(nèi)寫內(nèi)容.
public class test {
public static void main(String[] args) throws IOException {
File file = new File("text.txt");
file.createNewFile();
try(OutputStream outputStream = new FileOutputStream("text.txt")){
PrintWriter printWriter = new PrintWriter(outputStream);
printWriter.println("hello");
printWriter.flush();
}catch (IOException e){
e.printStackTrace();
}
}
}
此處封裝過后,就可以如常規(guī)輸出一樣,向文件里輸入內(nèi)容.代碼中flush()的作用在于清空輸入緩沖區(qū)的內(nèi)容,使println()輸出的內(nèi)容能成功到文件中.
其他要點
上述代碼中我們把OutputStream等輸入輸出流放在try()中,其目的是在代碼結(jié)束后可以自動調(diào)用close()方法釋放文件描述符表,防止忘記.這要求這個類要實現(xiàn)Closeable接口.
到此這篇關(guān)于Java文件管理操作的知識點整理的文章就介紹到這了,更多相關(guān)Java文件管理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何在 Spring Boot 中配置和使用 CSRF 保護(hù)
CSRF是一種網(wǎng)絡(luò)攻擊,它利用已認(rèn)證用戶的身份來執(zhí)行未經(jīng)用戶同意的操作,Spring Boot 提供了內(nèi)置的 CSRF 保護(hù)機(jī)制,可以幫助您防止這種類型的攻擊,這篇文章主要介紹了Spring?Boot?中的?CSRF?保護(hù)配置的使用方法,需要的朋友可以參考下2023-09-09
基于Spring的Maven項目實現(xiàn)發(fā)送郵件功能的示例
這篇文章主要介紹了基于Spring的Maven項目實現(xiàn)發(fā)送郵件功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
如何實現(xiàn)自定義SpringBoot的Starter組件
這篇文章主要介紹了實現(xiàn)自定義SpringBoot的Starter組件的示例代碼,想要自定義starter組件,首先要了解springboot是如何加載starter的,也就是springboot的自動裝配機(jī)制原理,本文結(jié)合示例代碼詳細(xì)講解,需要的朋友可以參考下2023-02-02

