一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Java文件流關閉和垃圾回收機制

Java文件流關閉和垃圾回收機制

2020-05-25 11:09lqh JAVA教程

本文是關于Java IO文件流和垃圾回收問題,一個小的測試程序搞清楚Java IO的問題,希望能幫助有需要的小伙伴

1.先看以下一段代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import java.io.FileInputStream;
public class TTT {
    public static void main(String[] args) throws Exception {
        for (int i = 0; i < 10; i++) {
            final String threadId = "thread_" + i;
            Thread thread = new Thread(new Runnable() {
                public void run() {
                    System.out.println(threadId + " started!");
                    try {
                        FileInputStream fis = new FileInputStream("/opt/test.log");
                        Thread.sleep(60 * 1000);
                    } catch (Exception ex) {
                        ex.printStackTrace();
                    }
                    System.out.println(threadId + " stopped!");
                }
            });
            thread.start();
        }
        Thread.sleep(10 * 60 * 1000);
    }
}

2.在linux上編譯并運行這個類,然后使用linux的命令/usr/sbin/lsof -p <pid>來查看這個程序打開的文件信息

?
1
2
3
4
5
6
7
8
9
10
11
$ /usr/sbin/lsof -p `ps -ef | grep java | grep TTT | awk '{print $2}'` | grep "test.log"
java 21562 fkong 3r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 4r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 5r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 6r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 7r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 8r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 9r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 10r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 11r REG 253,0 0 35471424 /opt/test.log
java 21562 fkong 12r REG 253,0 0 35471424 /opt/test.log

不管是在10個線程運行過程中還是運行完,使用lsof命令查看的結果都一樣,都可以看到有10個文件流沒有關閉。

3.下面我把這個代碼做了一些改動,就是在線程執行完之后,將所有線程置為null,如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import java.io.FileInputStream;
import java.util.ArrayList;
import java.util.List;
public class TTT {
    public static void main(String[] args) throws Exception {
        List<Thread> threads = new ArrayList<Thread>();
        for (int i = 0; i < 10; i++) {
            final String threadId = "thread_" + i;
            Thread thread = new Thread(new Runnable() {
                public void run() {
                    System.out.println(threadId + " started!");
                    try {
                        FileInputStream fis = new FileInputStream("/opt/test.log");
                        Thread.sleep(60 * 1000);
                    } catch (Exception ex) {
                        ex.printStackTrace();
                    }
                    System.out.println(threadId + " stopped!");
                }
            });
            thread.start();
            threads.add(thread);
        }
        Thread.sleep(2 * 60 * 1000);
        for (Thread thread : threads) {
            thread = null;
        }
        System.out.println("Clean up threads!");
        Thread.sleep(10 * 60 * 1000);
    }
}

再次在10個線程運行過程中和運行完畢后使用lsof查看,結果仍然類似,還是有10個文件流沒有關閉。

我再次做了一些改動,在將所有線程置為null以后,增加(或者說是催促JVM)做幾次gc操作,如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import java.io.FileInputStream;
import java.util.ArrayList;
import java.util.List;
public class TTT {
    public static void main(String[] args) throws Exception {
        List<Thread> threads = new ArrayList<Thread>();
        for (int i = 0; i < 10; i++) {
            final String threadId = "thread_" + i;
            Thread thread = new Thread(new Runnable() {
                public void run() {
                    System.out.println(threadId + " started!");
                    try {
                        FileInputStream fis = new FileInputStream("/opt/test.log");
                        Thread.sleep(60 * 1000);
                    } catch (Exception ex) {
                        ex.printStackTrace();
                    }
                    System.out.println(threadId + " stopped!");
                }
            });
            thread.start();
            threads.add(thread);
        }
        Thread.sleep(2 * 60 * 1000);
        for (Thread thread : threads) {
            thread = null;
        }
        System.out.println("Clean up threads!");
        
        System.gc();
        System.gc();
        System.gc();
        System.out.println("Finished GC!");
        
        Thread.sleep(10 * 60 * 1000);
    }
}

再次使用lsof查看,在運行中仍然還是可以看到那有10個文件流打開著,但是在“Finished GC!”之后,看到的結果是那10個打開的文件流都被關閉了。

最后,我干脆把那些設置thread為null的語句刪除了,運行的結果也和上面執行gc操作的結果一致。

最終,JVM中對于那些打開了沒有關閉的IO文件流,會在不再被使用的情況下,等到下次做Full GC的時候把他們全部回收,但是讓JVM去干這些事總歸還是不好的,還是那句老話,自己的事情自己做。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品久久久久影院色老大 | 欧美疯狂做爰3xxx | 四虎精品永久免费 | 国产精品视频久 | 精品国产品国语在线不卡丶 | 第一福利在线视频 | 亚洲国产在线视频中文字 | 精品国内自产拍在线视频 | 欧美日韩1区2区 | 美女狂揉尿口揉到失禁 | 日本久久啪啪婷婷激情五月 | 天天视频官网天天视频在线 | 日本免费一区二区三区a区 日本免费三片在线观看 | 1024日韩基地 | 无颜之月全集免费观看 | 国产成+人+综合+欧美 亚洲 | 国产亚洲一级精品久久 | 邪恶肉肉全彩色无遮盖 | 臀控福利大臀的网站 | 国产午夜视频在线观看网站 | 精品一区二区三区 不卡高清 | 日本aa大片在线播放免费看 | 精品国产线拍大陆久久尤物 | 成在线人免费视频一区二区三区 | 亚洲色图二区 | 成年美女黄网色大观看全 | 欧洲另类一二三四区 | 风间由美理论片在线观看 | 色网在线视频 | 91制片在线观看 | 狐媚小说 | 出轨同学会2在线观看 | 视频在线视频免费观看 | 色里番52kkm全彩 | 亚洲国产成人久久综合一区 | 秋霞色| 黄a在线观看 | 嫩草影院永久在线一二三四 | 蜜桃成熟3在线观看 | 搓光美女衣 | 男人的天堂久久精品激情 |