deux petits test sur le gc: je ne comprend pas leurs différences
Voilà, en voulant tester le gc, j'ai fini par faire deux petits test:
Code:
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
| package gc_test_case;
import java.lang.management.*;
public class Main {
public static void main(String[] args) {
test0();
//test1(); selon ce que je veux tester.
}
private static void test0() {
byte[] b_;
b_ = new byte[1];
for (int i = 0; i < 100; i++) {
b_ = new byte[1000 * 1000 * 40];
System.out.println(ManagementFactory.getMemoryMXBean().getHeapMemoryUsage());
}
}
private static void test1() {
byte[] b_;
// b_ = new byte[1];
for (int i = 0; i < 100; i++) {
b_ = new byte[1000 * 1000 * 40];
System.out.println(ManagementFactory.getMemoryMXBean().getHeapMemoryUsage());
}
}
private static void test2() {
byte[] b_;
b_ = new byte[1];
for (int i = 0; i < 100; i++) {
b_ = new byte[1000 * 1000 * 30];
System.out.println(ManagementFactory.getMemoryMXBean().getHeapMemoryUsage());
}
}
} |
Le test0 m'envoie un message d'erreur:
Code:
1 2 3 4
| Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at gc_test_case.Main.test0(Main.java:14)
at gc_test_case.Main.main(Main.java:7)
init = 0(0K) used = 40128792(39188K) committed = 45178880(44120K) max = 66650112(65088K) |
Le test1 et test2 fonctionnent.
Pourquoi cette différence et surtout pourquoi le test0 ne fonctionne pas?