Форум программистов, компьютерный форум CyberForum.ru

Время выполнения функции из C++ и из Java - Android

Войти
Регистрация
Восстановить пароль
Другие темы раздела
Android Доступ в интернет http://www.cyberforum.ru/android-dev/thread1140190.html
При попытке доступа в интернет URL url = new URL("http://xml.meteoservice.ru/export/gismeteo/point/148.xml"); URLConnection Conn = url.openConnection(); HttpURLConnection httpConn = (HttpURLConnection)Conn; в логе ошибка 04-06 12:21:15.981: E/ActivityManager(224): exception bw.write()java.io.IOException: Transport endpoint is not connected В манифесте права вроде бы стоят ...
Android Eclipse ndk странные ошибки Здравствуйте! Вот мой код: com_contedevel_tests_SpeedTest.h /* 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 http://www.cyberforum.ru/android-dev/thread1140124.html
Сделать чтобы при нажатие на кнопку в textview дата листалась назад Android
Здравствуйте, есть вопрос. как сделать чтобы при нажатие на кнопку в textview дата листалась назад. и чтобы месяц писался по Русски?
Android ManagedQuery deprecated
String columns = { Media.DATA, Media._ID, Media.TITLE, Media.DISPLAY_NAME }; Cursor cursor = parentA.managedQuery(Media.EXTERNAL_CONTENT_URI, columns, null, null, null); int fileColumn = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA); на моем телефоне работает попробовал на новом андройде, упало( пробовал заменить на Cursor cursor =...
Android Новый проект, обозначения http://www.cyberforum.ru/android-dev/thread1139762.html
Обновил Android SDK и плагины для Eclipse. Как выглядит вновь созданный проект: MainActivity.java package com.example.cyberforum; import android.support.v7.app.ActionBarActivity; import android.support.v7.app.ActionBar; import android.support.v4.app.Fragment; import android.os.Bundle;
Android SQLite синхронизация с MySQL Здравствуйте! Подскажите пожалуйста если кто то сталкивался как синхронизировать базу данных SQLite на андроиде и MySQL на сервере. Добавлено через 4 часа 20 минут Точней чтобы все данные из MySQL скопировались в SQLite подробнее

Показать сообщение отдельно
contedevel
 Аватар для contedevel
57 / 55 / 8
Регистрация: 07.10.2012
Сообщений: 589

Время выполнения функции из C++ и из Java - Android

06.04.2014, 13:02. Просмотров 760. Ответов 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 собственно, но по этому тесту выходит, что движок еще медлительней станет так.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:31. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru