本帖最后由 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中,主函数和垃圾回收器交替执行。 |
|