06.04.2014, 13:02. Просмотров 857. Ответов 8
Здравствуйте!
Пытаюсь оценить время выполнения функции из C++ и из Java. Они устроен одинаково - просто считают сумму, только написаны на разных языках.
Вот на C++:
com_contedevel_tests_SpeedTest.h
C++ |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
| /* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class com_contedevel_tests_SpeedTest */
#ifndef _Included_com_contedevel_tests_SpeedTest
#define _Included_com_contedevel_tests_SpeedTest
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: com_contedevel_tests_SpeedTest
* Method: getResult
* Signature: (I)F
*/
JNIEXPORT jfloat JNICALL Java_com_contedevel_tests_SpeedTest_getResult
(JNIEnv *, jobject, jint);
#ifdef __cplusplus
}
#endif
#endif |
|
tests.cpp
C++ |
1
2
3
4
5
6
7
8
9
10
| #include "com_contedevel_tests_SpeedTest.h"
JNIEXPORT jfloat JNICALL Java_com_contedevel_tests_SpeedTest_getResult
(JNIEnv * env, jobject obj, jint n) {
float tmp = 1.0f;
for(int i = 0; i < (int)n; i++) {
tmp += n - i;
}
return tmp;
} |
|
А вот сам Java class:
Java |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
| package com.contedevel.tests;
public class SpeedTest {
public native float getResult(int n);
static {
System.loadLibrary("tests");
}
public SpeedTest() {
}
public float getResult2(int n) {
float tmp = 1.0f;
for(int i = 0; i < n; i++) {
tmp += (n - i);
}
return tmp;
}
} |
|
Так, пытаюсь вычислить время:
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
| package com.contedevel.tests;
import android.app.Activity;
import android.os.Bundle;
import android.util.TimingLogger;
import android.widget.TextView;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.fragment_main);
SpeedTest test = new SpeedTest();
String tmp = "C++\n";
long nanoS = System.nanoTime();
float t = test.getResult(50000);
long nanoE = System.nanoTime();
tmp += "Result: " + String.valueOf(t) + "\n";
tmp += "Time: " + String.valueOf(nanoE - nanoS) + "_" + String.valueOf(nanoS) + "_" + String.valueOf(nanoE) + "\n";
tmp += "Java\n";
nanoS = System.nanoTime();
float t2 = test.getResult2(50000);
nanoE = System.nanoTime();
tmp += "Result: " + String.valueOf(t2) + "\n";
tmp += "Time: " + String.valueOf(nanoE - nanoS) + "_" + String.valueOf(nanoS) + "_" + String.valueOf(nanoE) + "\n";
TextView tvTest = (TextView) findViewById(R.id.testText);
tvTest.setText(String.valueOf(tmp));
}
} |
|
При запуске приложения C++ код выполняется почти в 2 раза быстрее, однако, при повороте экрана (пересоздании активити) Java выигрывает значительно, разница на порядок. При этом время выполнения того же C++ кода уже отображается
почти в 8 раз дольше...
Я не понимаю, что я не так делаю? И почему так происходит?
Я понимаю, что на вызов функции из библиотеки и возврата результата требуется время, но не столько же...
Добавлено через 3 минуты
Если кто знает, очень прошу ответить... Пытаемся увеличить производительность движка, вынеся длительные процессы в C++ код, как рекомендует Google собственно, но по этому тесту выходит, что движок еще медлительней станет так.