Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Оптимизация скорости доступа к эл. массива

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
FRONTMAN
Гость





СообщениеДобавлено: Чт Янв 16 2003 16:46    Заголовок сообщения: Оптимизация скорости доступа к эл. массива Ответить с цитатой

HELP! Скажите почему в VC так медленно присваиваются значения элементам массива.
Как это оптимизировать? Необходимо для быстрой растровой графики.
Вернуться к началу
Борис
Гость





СообщениеДобавлено: Чт Янв 16 2003 18:27    Заголовок сообщения: Re: Оптимизация скорости доступа к эл. массива Ответить с цитатой

Возможно (только предположение!), потому, что в VC/C++ доступ к элементам массива -- это функция operator[](тип*, int), которая (опять только предположение!) выполняется так:

тип operator[](тип* аргумент1, int аргумент2) {
return *(аргумент1+sizeof(тип)*аргумент2)
}

то есть при каждом обращении к элементу массива происходит умножение, суммирование и разыменование.

Быстрее будет использование простое разыменование указателя.

В качестве примера -- сканирование ASCIIZ-строки (однократные операции при инициализации не подсчитываю).

Получение значения элемента в форме массив[индекс]
for(индекс=0;массив[индекс]!=NULL;индекс++);

Выполняемые операции: умножение, суммирование, разыменование, сравнение, прирост индекса.

Получение значения элемента в форме *указатель
указатель=&нулевой_элемент;
while(*указатель++! =NULL);

Выполняемые операции: разыменование, сравнение, прирост указателя.

Скорость операций прирост индекса и прирост указателя одинакова. Разница: умножение, суммирование в случае массив[индекс].
Вернуться к началу
FRONTMAN
Гость





СообщениеДобавлено: Пт Янв 17 2003 19:56    Заголовок сообщения: Re: Оптимизация скорости доступа к эл. массива Ответить с цитатой

Автор: Вопрос снимаю. В моем VC6.0 Standart не работала опция оптимизации. После установки нового компилятора скорость возрасла в сотни раз.Так что с адресацией все в порядке
Вернуться к началу
Борис
Гость





СообщениеДобавлено: Пн Янв 20 2003 14:03    Заголовок сообщения: И в этом вся Micro$oft! Поубывав бы hадов. (-) Ответить с цитатой

-
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...