Навигация
Главная
Поиск
Форум
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
Содержание сайт... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Invision Power ... 65260
Организация зап... 63913
Модуль Forms 60833
Создание отчето... 60692
ТЕХНОЛОГИИ ДОСТ... 57011
Создание потоко... 56343
Пример работы с... 54252
Имитационное мо... 52465
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

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

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

Реклама



Подписывайся на 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 03:05:32 · 0 Комментариев · 2132 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
MP3 Архив v.2.0
Создание лабиринт...
ProLIB18
netBIOS
Pro-Download Sys...
ScrollCredit
Язык программиров...
Язык программиров...
Bitmap [для кнопок]
Rotolabel
TmxOutlookBarPro
Панель статистики...
Прграммирование в...
Аватары в комме...
Atb
Matrix2D
Библия для програ...
39 статьи по Delphi
MPTools
Язык программиров...

Топ загрузок
Приложение Клие... 100376
Delphi 7 Enterp... 83066
Converter AMR<-... 20046
Borland C++Buil... 11173
GPSS World Stud... 10888
Borland Delphi ... 8120
Turbo Pascal fo... 6973
Visual Studio 2... 4963
Калькулятор [Ис... 4355
FreeSMS v1.3.1 3510
Случайные статьи
Однократно использ...
Где батут купить д...
Рекурсивные методы...
экономия места на ...
Получить цвет пикс...
Этап 6 - выделение...
Сигналы SIGKILL и ...
Разработка програм...
Где купить battlef...
Как выбрать масшта...
При строгом соблюд...
Microsoft - в инте...
Установка голубого...
Немного о DMOZ
Предикат поиска по...
ЭТАП 4. ПРИМЕР РЕА...
В текстовом файле ...
Как идентифицирова...
Символические ссылки
PRINT (НАПЕЧАТАТЬ)
Удаление представл...
Пакеты компонентов
Циклы. Программа р...
О спецификации lOO...
Программные инфрас...
Статистика



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


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