A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© freshnboy 中级黑马   /  2016-3-21 16:08  /  514 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 freshnboy 于 2016-3-21 16:10 编辑

例子如下:
package com.heima.thread;

public class Demo1_Thread {

        /**
         * @param args
         * 证明jvm是多线程的
         */
        public static void main(String[] args) {
                for(int i = 0; i < 100000; i++) {
                        new Demo();
                }
               
                for(int i = 0; i < 10000; i++) {
                        System.out.println("我是主线程的执行代码");
                }
        }

}

class Demo {

        @Override
        public void finalize() {
                System.out.println("垃圾被清扫了");
        }
        
}
这里视频里没有解释清楚,很容易让人误解成“两个for循环交替执行说明JVM是多线程的”。

之所以出现demo中finalize方法不断被调用是因为垃圾回收器会不定期的清理垃圾,而清理之前会调用被清理对象的finalize方法。所以交替出现的原因并不是两个for循环交替执行。而是JVM中,主函数和垃圾回收器交替执行。

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马