Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
 Аватар для contedevel
57 / 55 / 13
Регистрация: 07.10.2012
Сообщений: 606

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

06.04.2014, 13:02. Показов 1656. Ответов 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 собственно, но по этому тесту выходит, что движок еще медлительней станет так.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.04.2014, 13:02
Ответы с готовыми решениями:

Прогресс выполнения функции AJAX и время выполнения
Здравствуйте. Как ни странно не нашел ответа на решение своей проблемы. Есть функция, которая обрабатывается AJAX-ом на стороне сервера....

время выполнения java
Уважаемые, прошу подсказать, что со временем? $ wc -l cpu/cpuout00-23/cpuout00 553395 cpu/cpuout00-23/cpuout00 $ $ $ time perl...

Используя О- символику, найдите время выполнения (как функции от N) процедуры или функции в наихудшем случае
Используя О- символику, найдите время выполнения (как функции от N) процедуры или функции в наихудшем случае. procedure mystery...

8
510 / 272 / 60
Регистрация: 14.12.2010
Сообщений: 548
06.04.2014, 14:23
Цитата Сообщение от contedevel Посмотреть сообщение
почти в 8 раз дольше... Я не понимаю, что я не так делаю? И почему так происходит?
Идея сомнительная весьма - в onCreate() методе производительности замер делать.
Замер в кнопки обработчик перенести следует.
Статистику получите запросов нескольких.
Профилировщики для целей ваших полезны будут.
1
420 / 357 / 47
Регистрация: 22.05.2013
Сообщений: 2,518
06.04.2014, 14:37
Личного опыта смены оринетации монитора нет(наоборот боролся с этим), но по тому что вычитал...
При смене ориентации куча других процессов запускается. ВСЕ программы получают сообщение и пытаются перестроится (включая ланчер с иконками и панелью заряда). А ваша получив это сообщение пытается запустить onCreate() на фоне остальных...
Послушайтесь совета EVP - тесты проводите в кнопках или других реакторах, а не в момент смены монитора. Согласно тому что я вычитал с++ ВСЕГДА (минимум) в 2 раза быстре явы!
1
 Аватар для contedevel
57 / 55 / 13
Регистрация: 07.10.2012
Сообщений: 606
06.04.2014, 15:07  [ТС]
Спасибо за ответы, учту! И еще вопрос, сам замер времени выполнения я правильно делаю? Т.е. можно ли таким способом получить правильную оценку производительности?

Добавлено через 8 минут
Изменил код так:
C++
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package com.contedevel.tests;
 
import android.app.Activity;
import android.os.Bundle;
import android.util.TimingLogger;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
 
public class MainActivity extends Activity {
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.fragment_main);
        final SpeedTest test = new SpeedTest();
        
        final TextView tvTest  = (TextView) findViewById(R.id.testText);
        Button btn = (Button) findViewById(R.id.btn);
        
        btn.setOnClickListener(new OnClickListener() {
 
            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                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";
                tvTest.setText(String.valueOf(tmp));
            }});
    }
 
}
Но C++ код все равно выполняется значительно медленнее...
0
510 / 272 / 60
Регистрация: 14.12.2010
Сообщений: 548
06.04.2014, 18:52
Цитата Сообщение от contedevel Посмотреть сообщение
сам замер времени выполнения я правильно делаю? Т.е. можно ли таким способом получить правильную оценку производительности?
Да. Да. (Имеет смысл делать оценку производительности только релизовой сборки)

Цитата Сообщение от contedevel Посмотреть сообщение
Но C++ код все равно выполняется значительно медленнее...
Такое возможно, если в режиме отладки проходить строчку 37 по шагам, сделав на ней паузу.
Если код будет выполняться нормально (без прерываний),
то скорость C++ метода будет минимум на два порядка превосходить скорость Java метода (даже на эмуляторе).
1
86 / 86 / 13
Регистрация: 03.03.2011
Сообщений: 1,873
06.04.2014, 20:11
спрошу не в тему
но как вы исполняете с++ код из явы?
0
 Аватар для contedevel
57 / 55 / 13
Регистрация: 07.10.2012
Сообщений: 606
06.04.2014, 20:14  [ТС]
Библиотеку подключаю. Или Вы о чем?
0
86 / 86 / 13
Регистрация: 03.03.2011
Сообщений: 1,873
06.04.2014, 20:19
об этом самом
скомпилированную?
0
 Аватар для contedevel
57 / 55 / 13
Регистрация: 07.10.2012
Сообщений: 606
07.04.2014, 13:25  [ТС]
Да, сперва компилируется библиотека, а затем уже сборка проекта идет
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.04.2014, 13:25
Помогаю со студенческими работами здесь

Время выполнения функции
Есть функция file_get_contents она парсит страничку. Но страница виснет когда сайт не доступен и грузит. как это ихбежать, поставит время...

Время выполнения функции
Доброго времени суток, пришла идея в голову, но при реализации возник вопрос. Допустим я написал плагин на jQuery при вызове которого ...

Время выполнения Функции
Всем привет, можно ли замерить скорость в цикле из 50-10 проходов? Пробывал gettimeofday, но он не настолько точен.

Время выполнения функции
Здравствуйте! Как в Hugs for Win32 узнать время выполнения функции, допустим такой: m :: -&gt; m = m (x:xs)= reverse xs

Время выполнения функции
Вопрос - как можно измерить время выполнения функции? clock() не подходит, т.к функции выполняются быстрее миллисекунды. есть способ как...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru