Optimizing Code in Java
Pavlos Kosmetatos
Lead Engineer @Wealthyhood
They are constraints that limit our application's speed and efficiency.
Imagine pouring water through a funnel - the narrowest part determines the flow rate!
System.nanoTime()
- High-precision time measurementlong
numberSystem.currentTimeMillis()
, measures wall clock time$$
long startTime = System.nanoTime();
// Code to measure
long endTime = System.nanoTime();
long duration = endTime - startTime;
// Measuring ArrayList.contains() performance import java.util.ArrayList; import java.util.List; List<Integer> numbers = new ArrayList<>(); for (int i = 0; i < 100000; i++) { numbers.add(i); }
long startTime = System.nanoTime(); boolean found = numbers.contains(99999); // O(n) operation long endTime = System.nanoTime();
long duration = endTime - startTime;
System.out.println("Time taken: " + duration + " ns");
// Convert to milliseconds
System.out.println("Time taken: " + duration / 1_000_000.0 + " ms");
Time taken: 1239000000 ns
Time taken: 1239ms
ArrayList.contains()
is an O(n)
operationlong totalTime = 0;
for (int i = 0; i < 3; i++) {
long start = System.nanoTime();
findElementLinear(data, target);
long iterationTime = System.nanoTime() - start;
totalTime += iterationTime;
System.out.println("Run " + (i+1) + ": " + iterationTime + " ns");
}
double averageTime = totalTime / 3.0;
System.out.println("Average: " + (long)averageTime + " ns");
Run 1: 3245678 ns
Run 2: 3198432 ns
Run 3: 3301234 ns
Average: 3248448 ns
// Assume we have calculated avgTimeA and avgTimeB already
System.out.println("Operation A is" + (avgTimeA / avgTimeB) + "x slower");
Operation A is 4x slower
Optimizing Code in Java