Навигация
Главная
Поиск
Форум
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
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
Имитационное мо... 59416
Реклама
Сейчас на сайте
Гостей: 9
На сайте нет зарегистрированных пользователей

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

База данных электронного документооборота на Delphi + бд Intebase
Моделирование процесса обработки заданий пакетным режимом работы с квант...
Моделирование процесса передачи данных по магистрали с основным и резерв...

Реклама



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

ПОДПИСЫВАЙСЯ на канал о программировании
Таблица 1. Стоимость памяти
Структура sizeof new
int 4 48
structc 1 48
structic 8 48
structip 8 48
structdc 16 64
structcd 16 64
structcdc 24 64
structii i 12 48
structiic 12 48
structc 12 12 48
structc 13 13 64
structc28 28 64
structc29 29 80
Числа в левом столбце дают возможность оценить размер структуры, возвращаемый sizeof. Начинать следует с суммирования значений sizeof для типов.
Это дает 8 байт для structip. Нужно также учитывать необходимость выравнивания, и поэтому, хотя компоненты структуры structcdc дают в сумме 10 байт, на самом деле она занимает 24 байта. Правый столбец дает нам представление о том, насколько неэкономично использует память оператор new. Любая структура, размер которой по sizeof составляет 12 байтов или меньше, при динамическом выделении занимает в памяти 28 байт. Структуры объемом 13-28 байт займут 64 байта памяти. В общем, размер выделенного блока будет кратен 16, и от 36 до 47 байтов будет потрачено зря. Это на удивление расточительно: в других системах для 8-байтовой записи хватало всего лишь 8 байт дополнительной информации.
В разделе 7.2 описана еще одна небольшая программа, позволяющая оценить сто- имость выполнения одной конкретной операции на С. Мы можем обобщить ее, получив программу time mod. с, которая выводит стоимость операций языка С по времени. Программа-предшественница этой была написана Брайаном Керииганом, Крисом ван Вайком и мной в 1991 году. Функция main состоит из последовательности строк- заголовков (Т), за которыми следуют строки М, измеряющие стоимость операций:
Т("Целочисленная арифметика")
М( {}) ,
М ( к + +) ;
М ( к = 1 + j ) ,
М ( к = ч - j ) .
С помощью этих и аналогичных строк получается следующий результат:
Цело ч исл ен на я арифметика (n = 5 000 )
{} 2 5 0 261 250 250 251 10
к + + 471 460 471 461 460 19
к = 1 + J 491 491 500 491 491 20
к = 1 - j 440 441 4*1 440 441 18
к = 1 * J 491 490 491 491 490 20
к = 1 / J 2414 2433 2424 2423 2414 97
к = 1 % J 2423 2414 2423 2414 2423 97
к = 1 & j 491 491 480 491 491 20
к = 1 1 J 440 441 441 440 441 18
В первом столбце указана операция, которая выполняется в следующем цикле:
for 1 = [1, п] for j = [1. n] операция
Следующие пять колонок содержат время выполнения такого цикла в тиках (в этой системе один тик равен миллисекунде) для пяти его запусков (все эти времена адекватны; неадекватное время выполнения позволяет выявить ошибки). В последнем столбце указана средняя стоимость одной операции в наносекундах. Первая строка таблицы говорит нам о том, что для одного выполнения тела пустого цикла требуется 10 не. Следующая строка показывает, что увеличение значения переменной к на единицу отнимает 9 не. Все арифметические и логические операции требуют примерно одного и того же времени, за исключением операций деления и нахождения остатка, которые требуют времени на порядок больше.
Этот подход позволяет грубо оценить стоимость операций на конкретном компьютере, но результатам не следует придавать слишком большое значение. Все эксперименты проводились с отключенной оптимизацией. Когда я включал ее, оптимизирующий компилятор удалял циклы и все времена оказывались нулевыми.
Работу выполняет макрос М, схема которого может быть записана на псевдокоде так:
#define М(ор)
вывод ор в виде строки timesum = О
for trial = [0. trials) start *= cl ock () for i = [1. n] f i = i
for j = [1. n] op
t = clock( ) - start print t timesum += t print le9*timesum / (n*n*trials*CLOCKS_PER_SEC)
Полный код программы, измеряющей стоимость операций по времени, можно найти на сайте книги.
Давайте теперь изучим результаты работы программы на моей системе. Поскольку времена выполнения циклов близки друг к другу, мы их просто опустим и будем приводить только среднее время выполнения одной операции в наносекундах.
Опубликовал vovan666 April 17 2013 04:05:32 · 0 Комментариев · 2446 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
FreeSMS v1.3.1
Программирование ...
Adapter (пример D...
mmmJlabel
Создание отчетов ...
Стелтинг Стивен, ...
Работа с базами д...
PDA версия сайта
CoolHints2k
Proeffectimage
WinAmp
3d Tank [Исходник...
Программа предназ...
Создание Web-сайт...
Архив значков
PDPcheck
Halcyon
Просмотр файлов и...
C++ Builder в за...
Паскаль и Дельфи....

Топ загрузок
Приложение Клие... 100512
Delphi 7 Enterp... 90199
Converter AMR<-... 20092
GPSS World Stud... 14943
Borland C++Buil... 12690
Borland Delphi ... 8936
Turbo Pascal fo... 7093
Калькулятор [Ис... 5126
Visual Studio 2... 5018
FreeSMS v1.3.1 3554
Случайные статьи
east.technologies.
Особенности модаль...
Синергетика
Условная компиляци...
Элементы управлени...
6.7. Формирование...
African vases
Services for Macin...
Invalid variable r...
Работа с форматом ...
14.3. Очереди с пр...
Разработать просто...
Внутреннее определ...
Вычислительная сто...
Методы оптимизации...
Файл главной компо...
Заказ презентации
Создание стандартн...
Примечание
Представления дере...
Специализация
Настраиваемые типы
Сети доступа, пост...
Определение контек...
Уроки Python для н...
Статистика



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


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