CPU-tijd analyseren
Je optimaliseert een applicatie voor financiële analyse die berekeningen uitvoert. Om het processorgebruik nauwkeurig te begrijpen, moet je een hulpprogramma implementeren dat de exacte CPU-tijd meet die door verschillende bewerkingen wordt verbruikt. Zo kun je bepalen welke berekeningen echt CPU-intensief zijn.
De benodigde lang.management-pakketten zijn al voor je geïmporteerd.
Deze oefening maakt deel uit van de cursus
Code optimaliseren in Java
Oefeninstructies
- Haal de
ThreadMXBean-instantie op uit de klasseManagementFactory. - Haal de CPU-tijd op voor de huidige thread.
Praktische interactieve oefening
Probeer deze oefening eens door deze voorbeeldcode in te vullen.
public class Main {
public static long getCpuTimeNano() {
// Retrieve the ThreadMXBean instance
ThreadMXBean threadMXBean = ____.____()
if (threadMXBean.isThreadCpuTimeSupported()) {
threadMXBean.setThreadCpuTimeEnabled(true);
// Return the current thread CPU time
return ____(Thread.currentThread().threadId());
} else {
System.out.println("CPU time measurement not supported");
return 0;
}
}
public static long calculateSum(long n) {
long sum = 0;
for (long i = 1; i <= n; i++) {
sum += i;
}
return sum;
}
public static long calculateSquareSum(long n) {
long sum = 0;
for (long i = 1; i <= n; i++) {
sum += i * i;
}
return sum;
}
public static void main(String[] args) {
long n = 100_000_000; // 100 million
long startSum = getCpuTimeNano();
long sum = calculateSum(n);
long endSum = getCpuTimeNano();
System.out.println("CPU time for sum: " +
((endSum - startSum) / 1_000_000.0) + " ms");
long startSquareSum = getCpuTimeNano();
long squareSum = calculateSquareSum(n);
long endSquareSum = getCpuTimeNano();
System.out.println("CPU time for square sum: " +
((endSquareSum - startSquareSum) / 1_000_000.0) + " ms");
double ratio = (endSquareSum - startSquareSum) / (double)(endSum - startSum);
System.out.println("Square sum takes " + ratio +
" times more CPU time than regular sum");
}
}