|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
||||||||||||||||
Резервирование памяти/освобождение памяти для трехмерного массива17.10.2012, 13:37. Показов 3749. Ответов 17
Метки нет (Все метки)
Необходимо создать трехмерный массив (A[Nx][Ny][Nz]), в котором элементы вдоль направления Z выли бы выровнены по 16 байт.
Есть две проблемы: 1. Как скрестить строку вроде
Кликните здесь для просмотра всего текста
2. Как корректно очистить память после выполнения программы? Вот такая связка приводит к ошибке во время очистки памяти: Кликните здесь для просмотра всего текста
Вылетает сообщение:
0
|
||||||||||||||||
| 17.10.2012, 13:37 | |
|
Ответы с готовыми решениями:
17
Динамическая загрузка и освобождение памяти для двумерного массива |
|
5500 / 4895 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
|
|
| 17.10.2012, 13:47 | |
|
Что в глаза бросается : for(i = 0; i<=Nx; i++). Нужно: for(i = 0; i<Nx; i++)
0
|
|
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
|
| 17.10.2012, 13:49 [ТС] | |
|
если не секрет, то почему так? планируется использовать элементы с 0 по Nx
0
|
|
|
Неэпический
|
||
| 17.10.2012, 13:53 | ||
|
Память освобождать в порядке, обратном выделению.
и sizeof(float **) == sizeof(float *) Добавлено через 1 минуту
1
|
||
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
|
| 17.10.2012, 13:55 [ТС] | |
|
Croessmah, большое спасибо! а сможете подсказать как быть с выравниванием?
0
|
|
|
Неэпический
|
||||||||||||
| 17.10.2012, 14:00 | ||||||||||||
|
Здесь у Вас выход за пределы массива из-за i<=Nx
0
|
||||||||||||
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
|
| 17.10.2012, 14:02 [ТС] | |
|
смысл в том, чтобы воспользоваться радостью SIMD (типа SSE) для действий над элементами массива по направлению Z
0
|
|
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
||
| 17.10.2012, 14:09 [ТС] | ||
|
lazybiz, извиняюсь, но не очень понял Вашу мысль.
как это можно прикрутить к строкам массива?
0
|
||
|
|
||||||
| 17.10.2012, 14:25 | ||||||
0
|
||||||
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
||||||
| 17.10.2012, 15:31 [ТС] | ||||||
|
lazybiz, большое спасибо! я, наверное, нифига не понял... но верно ли, что применительно к моей задаче это будет выглядеть как:
Кликните здесь для просмотра всего текста
0
|
||||||
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
|
| 17.10.2012, 16:07 [ТС] | |
|
то есть просто вместо строки:
U0[i][j] = (float *) malloc((Nz+1) * sizeof(float)); поставить: U0[i][j] = aligned_malloc( Nz+1, 16, &U0[i][j] ); и добавить функцию aligned_malloc в программу Верно? P.S. заранее очень извиняюсь если глупости спрашиваю
0
|
|
|
|
|
| 17.10.2012, 16:27 | |
|
Так. aligned_malloc возвращает два указателя, тот который передается как 3-й параметр нужен для того чтобы по нему освобождать память, т.е. тебе для этого нужен еще один массив указателей размером Nz.
И еще, зачем ты прибавляешь единицу к размеру?
0
|
|
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
|||
| 17.10.2012, 16:46 [ТС] | |||
|
float *U0zp16 = (float *)malloc((Nz+1) * sizeof(float)); а потом затолкать его в aligned_malloc: U0[i][j] = (float *) aligned_malloc( Nz+1, 16, &U0zp16 );
0
|
|||
|
4 / 4 / 0
Регистрация: 25.03.2011
Сообщений: 28
|
||
| 17.10.2012, 17:25 [ТС] | ||
|
size размер массива который хотим; (alignment - 1) - дополнительное место для выравнивания; а вторая строка производит выравнивание Верно ли понял?
0
|
||
|
|
||
| 17.10.2012, 19:32 | ||
|
Не задавай глобальные вопросы. Спрашивай что именно ты не понимаешь.
0
|
||
| 17.10.2012, 19:32 | |
|
Помогаю со студенческими работами здесь
18
Освобождение памяти после динамического массива Освобождение памяти у динамического массива char Освобождение памяти динамического массива структур Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Вывод данных через динамический список в справочнике
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
|
|
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
|
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию.
2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
|
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
|
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO
Апнулись до NET10.
Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта
так и в интерактивном режиме. из сложностей - чисто функциональный подход.
Решил. . .
|