blob: 032e70011a89dac207fbf05b87d79a7847b73454 [file] [log] [blame]
/*
* Copyright (C) 2015 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
public class Main {
public Main() {
}
private static final String MSG = "ABCDE";
native int perfJniEmptyCall();
native int perfSOACall();
native int perfSOAUncheckedCall();
int runPerfTest(long N) {
long start = System.nanoTime();
for (long i = 0; i < N; i++) {
char c = MSG.charAt(2);
}
long elapse = System.nanoTime() - start;
System.out.println("Fast JNI (charAt): " + (double)elapse / N);
start = System.nanoTime();
for (long i = 0; i < N; i++) {
perfJniEmptyCall();
}
elapse = System.nanoTime() - start;
System.out.println("Empty call: " + (double)elapse / N);
start = System.nanoTime();
for (long i = 0; i < N; i++) {
perfSOACall();
}
elapse = System.nanoTime() - start;
System.out.println("SOA call: " + (double)elapse / N);
start = System.nanoTime();
for (long i = 0; i < N; i++) {
perfSOAUncheckedCall();
}
elapse = System.nanoTime() - start;
System.out.println("SOA unchecked call: " + (double)elapse / N);
return 0;
}
public static void main(String[] args) {
System.loadLibrary(args[0]);
long iterations = 1000000;
if (args.length > 1) {
iterations = Long.parseLong(args[1], 10);
}
Main m = new Main();
m.runPerfTest(iterations);
System.out.println("Done");
}
}