-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMarkAndCompact.java
43 lines (40 loc) · 1.34 KB
/
MarkAndCompact.java
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
38
39
40
41
42
43
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Map;
import java.util.Map.Entry;
import java.util.PriorityQueue;
public class MarkAndCompact extends MarkAndSweep {
@Override
protected void writeNewHeap(String path) {
File file = new File(path);
PriorityQueue<Map.Entry<Integer, Node>> newHeap = new PriorityQueue<>((i, j) -> i.getValue().getStart() - j.getValue().getStart());
for (Map.Entry<Integer, Node> object : objects.entrySet()) {
if (object.getValue().getVisited())
newHeap.add(object);
}
try {
BufferedWriter writer = new BufferedWriter(new FileWriter(file));
writer.write("object-identifier,memory-start,memory-end\n");
int nextMemoryAddress = 0;
while (newHeap.size() > 0) {
Entry<Integer, Node> object = newHeap.poll();
int size = object.getValue().getEnd() - object.getValue().getStart();
writer.write(object.getKey() + "," + nextMemoryAddress + "," + (nextMemoryAddress + size) + "\r\n");
nextMemoryAddress += size + 1;
}
writer.close();
} catch (IOException e) {
System.out.println(e.getMessage());
}
}
public static void main(String[] args) {
GarbageCollector mc = new MarkAndCompact();
mc.readHeap(args[0]);
mc.readRoots(args[1]);
mc.readPointers(args[2]);
mc.mark();
mc.writeNewHeap(args[3]);
}
}