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

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

Информационная система - транспортный парк на Turbo Pascal (База данных)...
Обработка задач на ЭВМ на GPSS + Пояснительная записка
База данных электронного документооборота на 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 Комментариев · 2397 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Киллер окон
Delphi. Учимся на...
Delphi World 6.0
Программирование ...
Программа рисует ...
API (Применение A...
Игра Car [Исходни...
OnlineIP
Песочные часы
BDEPack
AboutSystem
Язык программиров...
Delphix Sample [И...
DelTrayIcon [Исхо...
NetGraph [Исходни...
Обучение Borland ...
TmxOutlookBarPro
Domen Name IP
C++ Builder: Книг...
AUTOWEB

Топ загрузок
Приложение Клие... 100474
Delphi 7 Enterp... 87520
Converter AMR<-... 20081
GPSS World Stud... 13126
Borland C++Buil... 11946
Borland Delphi ... 8638
Turbo Pascal fo... 7042
Visual Studio 2... 5002
Калькулятор [Ис... 4862
FreeSMS v1.3.1 3544
Случайные статьи
Построение дерева ...
Смысл разработки и...
London\H RManagers...
Протоколы группово...
Как вставить растр...
29юс20з Почтовый с...
Арифметическое выр...
Сокрытие конфиденц...
Файлы в Турбо Прол...
Как мне пометить с...
Шифрование алгорит...
Практическая реали...
Всплывающие сообщения
Ответы см
Вирусный трафик
Меморандум по холо...
Стандартная библио...
Возникновение взаи...
Использование Visu...
Логические схемы а...
Как зарегистрирова...
Akismet и All -in ...
MySQL и Perl: взаи...
выполнить привязку...
Правила работы с И...
Статистика



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


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