Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Создание отчето... 63296
Модуль Forms 63202
ТЕХНОЛОГИИ ДОСТ... 59870
Пример работы с... 58762
Имитационное мо... 55326
Реклама
Сейчас на сайте
Гостей: 13
На сайте нет зарегистрированных пользователей

Пользователей: 13,077
новичок: radikrr
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

База данных электронного документооборота на Delphi + бд Intebase
Принадлежит ли точка пересечению двух окружностей на Turbo Pascal + Отче...
Моделирование интернет кафе на GPSS + Отчет

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Измерение времени и программирование
Как понять, достаточно ли быстро работает фрагмент кода? Как узнать, насколько быстро работает данная операция? Во многих ситуациях, связанных с измерением времени, можете просто посмотреть на часы (секундомер, стенные или наручные часы). Это не научно и не точно, но, если не произойдет чего-то непредвиденного, вы можете прийти к выводу, что программа работает достаточно быстро.

Также вам может показаться, что такая тема как
http://alltools51.ru/chto-vybrat-ooo-ili-ip/ никак не связана и даже не тематична с программированием. Хотя, может быть и связана.
В любом случае все-таки зайдите на сайт alltools51.ru
Тема ип или ооо что выбрать там представлена весьма широко.

Тем не менее этот подход неприемлем для тех, кого беспокоят вопросы производительности программ.
^ Если вам необходимо измерять более мелкие интервалы времени или вы не хотите сидеть с секундомером, вам следует научиться использовать возможности компьютера, так как он знает, как измерить время. Например, в системе Unix достаточно просто поставить перед командой слово time, чтобы система вывела продолжительность ее выполнения.


Можете также использовать команду time, чтобы выяснить, сколько времени заняла компиляция исходного файла x.cpp. Обычно компиляция выполняется по команде
g++ x.cpp
Для того чтобы измерить продолжительность компиляции, поставьте перед ней слово time.
time g++ x.cpp
Система откомпилирует файл x.cpp и выведет на экран затраченное время. Это простой и эффективный способ измерения продолжительности работы небольших программ. Не забудьте выполнить измерения несколько раз, потому что на продолжительность выполнения программы могут влиять другие действия, выполняемые на вашем компьютере. Если вы получите примерно три одинаковых ответа, то можете им доверять.
=i|


А что, если вы хотите измерить интервал времени, длящийся всего несколько миллисекунд? Что, если вы хотите выполнить свои собственные, более подробные измерения, связанные с работой части вашей программы? Продемонстрируем использование функции clock() из стандартной библиотеки, позволяющей измерить продолжительность выполнения функции do_something().
#include
#include using namespace std;
int main()
{
int n = 10000000; // повторяем do_something() n раз
clock_t t1 = clock(); // начало отсчета
if (t1 == clock_t(-1)) { // clock_t(-1) значит "clock()
// не работает" cerr << "Извините, таймер не работает \n"; exit(1);
}
for (int i = 0; i clock_t t2 = clock(); // конец отсчета if (t2 == clock_t(-1)) {
cerr << "Извините, таймер переполнен \n"; exit(2);
}
cout << "do_something() " << n << " раз занимает"
<< double(t2-t1)/CLOCKS_PER_SEC << " сек"
<< " (точность измерений: "
<< CLOCKS PER SEC << " сек)^";
}
Функция clock() возвращает результат типа clock_t. Явное преобразование double(t2-t1) перед делением необходимо, поскольку тип clock_t может быть целым число. Точный момент запуска функции clock() зависит от реализации;
функция clock() предназначена для измерения интервалов времени в пределах одного сеанса выполнения программы. При значениях t1 и t2, возвращаемых функцией clock(), число double(t2-t1)/CLOCKS_PER_SEC является наилучшим приближением времени, прошедшего между двумя вызовами функции clock() и измеренного в секундах. Макрос CLOCKS_PER_SEC (тактов в секунду) описан в заголовке .
Если функция clock() для процессора не предусмотрена или временной интервал слишком длинный, функция clock() возвращает значение clock_t(-1).
Функция clock() предназначена для измерения временных интервалов, длящихся от доли секунды до нескольких секунд. Например, если (что бывает довольно часто) тип clock_t представляет собой 32-битовый тип int со знаком и параметр CLOCKS_PER_SEC равен 1000000, мы можем использовать функцию clock() для измерения интервалов времени продолжительностью от 0 до 2000 секунд (около половины часа), выраженных в микросекундах.

Напоминаем: нельзя доверять любым измерениям времени, которые нельзя ~* повторить, получив примерно одинаковые результаты. Что значит “примерно одинаковые результаты”?

Примерно 10%. Как мы уже говорили, современные компьютеры являются быстрыми: они выполняют миллиард инструкций в секунду. Это значит, что вы не можете измерить продолжительность ни одной операции, если она не повторяется десятки тысяч раз или если программа не работает действительно очень медленно, например, записывая данные на диск или обращаясь в веб. В последнем случае вы должны повторить действие несколько сотен раз, но медленная работа программы должна вас насторожить.
Опубликовал katy April 28 2015 16:29:42 · 0 Комментариев · 1539 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Профессиональное ...
C++ Builder 6 СПР...
Графика в проекта...
Пишем программы и...
Email
Calendar
CaptionButton
Иллюстрированный ...
PHP: настольная к...
EditButton
Ведение справочны...
Стелтинг Стивен, ...
Библия хакера 2. ...
SearchAndReplace
Учебник по создан...
Векторный редакто...
Как программирова...
BIOS
PrevInst
Программирование ...

Топ загрузок
Приложение Клие... 100426
Delphi 7 Enterp... 85342
Converter AMR<-... 20062
GPSS World Stud... 12257
Borland C++Buil... 11463
Borland Delphi ... 8428
Turbo Pascal fo... 7014
Visual Studio 2... 4985
Калькулятор [Ис... 4686
FreeSMS v1.3.1 3530
Случайные статьи
Метод Чёрчмена-Акофа
Заголовок приема
Если требуется убе...
Использование вспы...
Поиск максимальног...
Alpha Slots Online...
Карта END
Пул соединений
Оценка точности оп...
Объяснение решения
Амперсанд (&)
Статичное содержим...
Главная идея Томпсона
Металлические дета...
Физическая природ...
«Умный» массив
Ввод и вывод широк...
Identifier expected
2.1.2. Переменные
Пример: интрузивны...
Язык С: операции н...
Окно предваритель...
Восприятие и замет...
Права пользователя...
излишними привилег...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?