Комментарии:
Очень полезное видео. Спасибо! Именно так и работает контейнер vectot из C++
ОтветитьРоскошно.
ОтветитьВот эта штука выглядит плохо (и в левой и в правой части есть data) =>
data = append(data, &length, &capacity ...
Можно использовать указатель на указатель, в его значении хранить адрес массива, а в функцию передавать адрес этого указателя.
unsigned int dataPtr = (unsigned int)data;
for(char i=1; i<25; i++) {
append(&dataPtr, &length, &capacity,i);
}
Ну и слегка доработать саму функцию так, чтобы адрес dataPtr нигде не менялся, а в значении по адресу лежал адрес массива и он по мере увеличения памяти будет меняться
Добрый день! Спасибо за урок! Переписал Вашу программу как у Вас было написано, но у меня проверка ругалась ( на size_t) и не хотела компилировать. После того как поменял на int и поставил фигурные скобки в строке 37 все заработало. Я новичок и просто интересно почему так у меня получилось? Проверял так: gcc -Wall -Werror -Wextra -o ucheba ucheba.c
ОтветитьMy brain ram got overflow error.
ОтветитьЗдравствуйте. Долго ждал урока с материалами по работе с кучей. Объяснения очень полезны, даже приведён такой прикладной пример.
Я хотел спросить у Вас совета. Я бы хотел выделить выровненную память в куче, скажем, по адресу, кратному 64. После того, как использовал эту память, мне захотелось изменить её размер, при этом сохранив выравнивание. Если новый размер меньше предыдущего, то функция realloc удовлетворит моим требованиям. Но, если мне понадобится выделить объём памяти больший, то realloc, в лучшем случае, сможет захватить дополнительный кусок на месте, а в худшем - скопирует в новую область. Но тогда и выравнивание, вероятно, потеряется. Как мне кажется, самый простой вариант, если он возможен следующий. Нужно проверить: свободна ли память за границей текущего массива. Если да – применить realloc. Если нет – то выделить malloc’ом в новом месте с запасом на выравнивание и потом уже скопировать туда данные, а старую область освободить.
Не подскажете: возможно ли осуществить проверку области (возможно перебором адресов) за массивом на занятость? Если да - насколько это по силам программисту по C/C++ с базовыми навыками? Может, существует такая библиотечная функция? Функции aligned_malloc, aligned_realloc, aligned_free не подходят.
Возможен вариант из Вашего примера без realloc, конечно, но не хотелось бы лишний раз копировать данные в новую область, если возможно захватить последующие адреса.
Заранее приношу свои извинения, если вопрос не по теме или слишком узкий.
как всегда, лайк, за качественную подачу материала!!!
Ответитькакая чудесная функция realloc()! и расширит, и скопирует, и подчистит.
очень интересный урок,спасибо Сергей!
Вот это уже серьезные дела) Спасибо за видео!
ОтветитьА раст будет?)
ОтветитьСпасибо за науку. Хороший, толковый урок. Все как всегда на высшем уровне!
Ответить