Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/15: Рейтинг темы: голосов - 15, средняя оценка - 4.80
3 / 3 / 7
Регистрация: 19.10.2009
Сообщений: 225

Сравнение скоростей операций в Java.

21.10.2010, 13:12. Показов 2954. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Какая операция выполняется за меньшее время - операция извлечения значения из массива или операция умножения? Например, следующий код:

int count = 1, val = 0, limit = 10000;
int[] value = {2, 4, 6};

long time = System.currentTimeMillis();
for(int i = 0; i<limit; i++)
{
val = value[count];
}
System.out.println(System.currentTimeMil lis()-time);

time = System.currentTimeMillis();
for(int i = 0; i<limit; i++)
{
val = count*2;
}
System.out.println(System.currentTimeMil lis()-time);

при первом запуске выдает:
0
0

При втором и последующих:
0
10

При увеличении значения limit до миллиона, например, результаты такие:

Первый запуск:
10
10

Второй и последующие:
20
0

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

Да и вот еще что. Имеет ли смысл следующий код:

if(b>0)
b <<= 8;

Другими словами, какая операция быстрее if(b>0) или b <<= 8?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.10.2010, 13:12
Ответы с готовыми решениями:

Выполнение нескольких операций в java как осуществляется ?
У меня в коде идет выполнение какой-либо одной из операций. Как осуществить выполнение сразу нескольких операций по очереди? У меня после...

Есть ли в java перегрузка операций?
народ!!! скажите плиз есть ли в java перегрузка операций??? очень надо а никаких даже намеков на ето не нашел...

Сравнение двух дат в JAVA
Здравствуйте! Имеется массив, в котором находится города, температура воздуха в данных городах и дата на целый год. Нужно по сегодняшней...

4
0 / 0 / 0
Регистрация: 11.02.2010
Сообщений: 111
21.10.2010, 16:38
ну измерь время выполнения операций и узнаешь
0
0 / 0 / 0
Регистрация: 11.02.2010
Сообщений: 111
21.10.2010, 16:40
тьфу ты, сообщение твое не дочитал =)
тогда загони всё в цикл, сделай миллион этих операций, измерь общее время, тогда может картина нарисуется =)
0
3 / 3 / 0
Регистрация: 25.08.2010
Сообщений: 213
21.10.2010, 17:50
Маленький вопрос - зачем сравнивать по времени выполнения побитовый сдвиг и операцию сравнения.
если тебе нужна максимальная скорость использй хэш таблицы - они по идее самые скоростные.
0
3 / 3 / 7
Регистрация: 19.10.2009
Сообщений: 225
24.10.2010, 10:10  [ТС]
Скорости я мерял. Но, как уже говорил, результаты различные получаются. Потому и спросил. В принципе, я для себя уже все решил - в теоретическом плане интересно. Почти что нигде не написано как что работает. Разве что в JVM Specification
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.10.2010, 10:10
Помогаю со студенческими работами здесь

Сравнение двух xml на java
Ребята, встала задача сравнения двух xml файлов (на java) с тем чтобы обновить один из них данными из другого, но без использования бд....

Сравнение слов в массиве строк Java
Добрый день! Помогите пожалуйста с задачей.) &quot;В файле содержатся фамилии людей. Нужно считать их из файла, и сравнить. Если есть...

Сравнение строк (String) в java. Мини гайд для начинающих
Всем привет! Одна из самых распространенных ошибок начинающих, выражаемая в очень частых темах типа – «не работает условие…», является...

Подскажите с if на JAVA. Сравнение данных из базы с переменной String
Здравствуйте! Есть база на oracle, в ней таблица и необходимый мне столбец типа varchar2(300). Вывод: Почему не...

Преобразование скоростей классическим законом сложения скоростей Галилея
Чему равна относительная погрешность б(бетта) вычислений при замене правила преобразования скоростей классическим законом сложения...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в 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