国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - JAVA教程 - Java文件流關(guān)閉和垃圾回收機制

Java文件流關(guān)閉和垃圾回收機制

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

本文是關(guān)于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命令查看的結(jié)果都一樣,都可以看到有10個文件流沒有關(guān)閉。

3.下面我把這個代碼做了一些改動,就是在線程執(zhí)行完之后,將所有線程置為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查看,結(jié)果仍然類似,還是有10個文件流沒有關(guān)閉。

我再次做了一些改動,在將所有線程置為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!”之后,看到的結(jié)果是那10個打開的文件流都被關(guān)閉了。

最后,我干脆把那些設(shè)置thread為null的語句刪除了,運行的結(jié)果也和上面執(zhí)行g(shù)c操作的結(jié)果一致。

最終,JVM中對于那些打開了沒有關(guān)閉的IO文件流,會在不再被使用的情況下,等到下次做Full GC的時候把他們?nèi)炕厥眨亲孞VM去干這些事總歸還是不好的,還是那句老話,自己的事情自己做。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久国产精品一区二区三区 | 精品久久99| 欧美精品一区二区久久 | 丝袜久久 | 一区二区三区久久久久 | 91香蕉视频 | 日韩中文字幕在线播放 | 久久久久高清视频 | 综合精品久久久 | 青青操av在线 | 中文在线一区二区 | 麻豆产精国品免费入口 | 国产精品久久久久久久久久久新郎 | 久久综合九九 | 好看毛片 | 1000部精品久久久久久久久 | 日韩有码在线播放 | 成人亚洲一区 | 99国产一区 | 日韩精品一区二区三区av | 国产精品乱码久久 | 国产精品久久久久久久久久久久久 | 国产日产久久高清欧美一区 | 国产成人精品一区二区三区视频 | 亚洲精品不卡 | av一区二区在线观看 | 我和我的祖国电影在线观看免费版高清 | 亚洲精品二区 | 97久久精品人人做人人爽50路 | 在线观看国产 | 国产精品欧美一区二区三区 | 综合久久亚洲 | 视频黄色免费 | 黄色二区 | 欧美视频精品在线 | 日本免费精品视频 | 国产高潮国产高潮久久久91 | 中文字幕日韩欧美 | 亚洲午夜网 | 91视频在线免费观看 | 在线视频中文字幕 |