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

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

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去干這些事總歸還是不好的,還是那句老話,自己的事情自己做。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产成人精品本亚洲 | 天堂俺去俺来也www久久婷婷 | 国产成人一区二区三区视频免费蜜 | 欧美日韩国产一区二区三区在线观看 | 99爱视频 | 亚洲乱亚洲乱妇41p 亚洲乱码一区二区三区国产精品 | 精品国产福利一区二区在线 | 99在线精品视频 | 久久久久久久电影 | 午夜影院和视费x看 | 日本一区二区在线不卡 | 欧美激情综合 | 成人福利网站含羞草 | 91久久国产青草亚洲 | x8x8在线观看 | 国产在线欧美日韩精品一区二区 | 美女污视频 | 亚洲热图| h片在线看 | 日本色播| 国产91素人搭讪系列天堂 | 韩日视频在线 | 国自产拍在线天天更新91 | brazzers欧美教师 | 好爽好粗 | 青青青手机在线视频 | 狠狠干2016 | 97爱sese| 日韩精品一区二区三区老鸭窝 | 蜜汁肉桃全文免费阅读 | 牧教师 | 短篇艳妇系列 | 午夜电影三级还珠格格 | 999久久免费高清热精品 | 免费视频精品一区二区三区 | 午夜精品在线 | 午夜福利院电影 | 国产果冻传媒 | 好男人资源在线观看免费的 | 天天做天天爱天天综合网 | 唯美清纯 自拍偷 |