Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

У n-мерных массивов (n>1) есть одна неприятная тонкость:

Отправлено smb 03 октября 2008 г. 18:25
В ответ на: По вчерашнему вопросу. Спасибо откликнувшимся. То что надо отправлено axalay 03 октября 2008 г. 16:34

Адрес произвольного элемента A[i][j] массива A[N][M] вычисляется как
&A[i][j] == (A + i * M + j)

Самое неприятное здесь - это операция умножения. В случае критического ко времени выполнения кода лучше использовать другие варианты организации данных (например, массив указателей на одномерные массивы - здесь операция умножения не нужна).

С большой вероятностью оптимизатор не будет использовать умножение в случае последовательного перебора элементов массива. Однако надеятся на оптимизатор - не есть хорошо.

PS. ну а если скорость для Вас не важна, то лучше предпочесть тот вариант, который лучше читается.


Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 34:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru