объясняя функцию void* append() проехался без остановки. еще и ускоряя речь, словно щас забудет мысль за то про кучу полторы минуты топтались - "благосклонен", "полновластный хозяин"
Вот эта штука выглядит плохо (и в левой и в правой части есть data) => data = append(data, &length, &capacity ... Можно использовать указатель на указатель, в его значении хранить адрес массива, а в функцию передавать адрес этого указателя. unsigned int dataPtr = (unsigned int)data; for(char i=1; i
Здравствуйте. Долго ждал урока с материалами по работе с кучей. Объяснения очень полезны, даже приведён такой прикладной пример. Я хотел спросить у Вас совета. Я бы хотел выделить выровненную память в куче, скажем, по адресу, кратному 64. После того, как использовал эту память, мне захотелось изменить её размер, при этом сохранив выравнивание. Если новый размер меньше предыдущего, то функция realloc удовлетворит моим требованиям. Но, если мне понадобится выделить объём памяти больший, то realloc, в лучшем случае, сможет захватить дополнительный кусок на месте, а в худшем - скопирует в новую область. Но тогда и выравнивание, вероятно, потеряется. Как мне кажется, самый простой вариант, если он возможен следующий. Нужно проверить: свободна ли память за границей текущего массива. Если да - применить realloc. Если нет - то выделить malloc’ом в новом месте с запасом на выравнивание и потом уже скопировать туда данные, а старую область освободить. Не подскажете: возможно ли осуществить проверку области (возможно перебором адресов) за массивом на занятость? Если да - насколько это по силам программисту по C/C++ с базовыми навыками? Может, существует такая библиотечная функция? Функции aligned_malloc, aligned_realloc, aligned_free не подходят. Возможен вариант из Вашего примера без realloc, конечно, но не хотелось бы лишний раз копировать данные в новую область, если возможно захватить последующие адреса. Заранее приношу свои извинения, если вопрос не по теме или слишком узкий.
Спасибо большое за видео! Мы можем выделять отдельно память с помощью realloc под каждый новый элемент массива? Я попробовал, получилось. Вводим элементы, пока не будет введено -1. Вот код: #include #include int main(){ int* arr = NULL; int n; int i = 0;
В языке Си new не существует. Это оператор языка С++ и о нем дальше, когда будет переход к С++. Видите, как важно разделять эти два языка и учить их последовательно: сначала Си, а потом С++.
@@selfedu_rus Я понимаю, что это части разных языков. Просто задумываюсь о том, актуально ли сейчас вообще ещё учить именно язык С, если в С++ всё работает намного стабильнее. Мой компилятор в Visual Studio уже много команд из Си даже не распознает или пишет "unsafe". Результаты работы malloc и calloc только в указатели типа void* давал записывать. Интересно услышать Ваше мнение
Я хочу засунуть слово в переменную :ЕГГОГ Я хочу засунуть данные в переменную:ЕГГОГ Какой хмырь придумал эти типы данных и почему кислое нельзя превратить в длинное на ходу Какой извращенец подумал и сказал...ооо да мне нравится ставить точку с запятой после каждой строчки мм как удобно 2д массив нельзя впихнуть в 3д массив Весь язык пропитан какими то заборами Так нельзя Так не делай Так я не могу Аж моча закипает когда я вижу этот синтаксис там больше слов чем самой сути кода ёлы палы
Добрый день! Спасибо за урок! Переписал Вашу программу как у Вас было написано, но у меня проверка ругалась ( на size_t) и не хотела компилировать. После того как поменял на int и поставил фигурные скобки в строке 37 все заработало. Я новичок и просто интересно почему так у меня получилось? Проверял так: gcc -Wall -Werror -Wextra -o ucheba ucheba.c
size_t - это переопределенный целочисленный тип (прописывается в одном из заголовочных файлов, вроде, stddef.h). Его определение выглядит примерно так: typedef unsigned int size_t;
какая чудесная функция realloc()! и расширит, и скопирует, и подчистит.
очень интересный урок,спасибо Сергей!
Спасибо за твои труды! Хорошо и подробно все объясняешь, в отличии от многих других курсов :)
Вот это уже серьезные дела) Спасибо за видео!
как всегда, лайк, за качественную подачу материала!!!
Спасибо. Трудно представить более простое объяснение
Курс вообще топ, всем советую , для начинающих ❤❤❤❤
Очень полезное видео. Спасибо! Именно так и работает контейнер vectot из C++
Роскошно.
Классно, спасибо!
Спасибо.
My brain ram got overflow error.
объясняя функцию void* append() проехался без остановки. еще и ускоряя речь, словно щас забудет мысль
за то про кучу полторы минуты топтались - "благосклонен", "полновластный хозяин"
Вот эта штука выглядит плохо (и в левой и в правой части есть data) =>
data = append(data, &length, &capacity ...
Можно использовать указатель на указатель, в его значении хранить адрес массива, а в функцию передавать адрес этого указателя.
unsigned int dataPtr = (unsigned int)data;
for(char i=1; i
Сложный урок. Спасибо
Здравствуйте. Долго ждал урока с материалами по работе с кучей. Объяснения очень полезны, даже приведён такой прикладной пример.
Я хотел спросить у Вас совета. Я бы хотел выделить выровненную память в куче, скажем, по адресу, кратному 64. После того, как использовал эту память, мне захотелось изменить её размер, при этом сохранив выравнивание. Если новый размер меньше предыдущего, то функция realloc удовлетворит моим требованиям. Но, если мне понадобится выделить объём памяти больший, то realloc, в лучшем случае, сможет захватить дополнительный кусок на месте, а в худшем - скопирует в новую область. Но тогда и выравнивание, вероятно, потеряется. Как мне кажется, самый простой вариант, если он возможен следующий. Нужно проверить: свободна ли память за границей текущего массива. Если да - применить realloc. Если нет - то выделить malloc’ом в новом месте с запасом на выравнивание и потом уже скопировать туда данные, а старую область освободить.
Не подскажете: возможно ли осуществить проверку области (возможно перебором адресов) за массивом на занятость? Если да - насколько это по силам программисту по C/C++ с базовыми навыками? Может, существует такая библиотечная функция? Функции aligned_malloc, aligned_realloc, aligned_free не подходят.
Возможен вариант из Вашего примера без realloc, конечно, но не хотелось бы лишний раз копировать данные в новую область, если возможно захватить последующие адреса.
Заранее приношу свои извинения, если вопрос не по теме или слишком узкий.
Я так понимаю malloc и free это аналог new и delete в с++?
не совсем, new и delete дополнительно вызывают конструктор и деструктор класса
@@selfedu_rus спасибо, буду разбираться
Спасибо большое за видео!
Мы можем выделять отдельно память с помощью realloc под каждый новый элемент массива? Я попробовал, получилось. Вводим элементы, пока не будет введено -1. Вот код:
#include
#include
int main(){
int* arr = NULL;
int n;
int i = 0;
scanf("%d", &n);
while (n != -1) {
arr = realloc(arr, sizeof(int));
arr[i] = n;
i++;
scanf("%d", &n);
}
for (int j = 0; j < i; j++) {
printf("%d ", arr[j]);
}
free(arr);
return 0;
}
А как же отчистить динамический массив ar, у тебя ж получается утечка памяти
кажется я понял, realloc автоматически ее подчищает
free(указатель);
В этих функциях есть смысл при том, что существует new?
В языке Си new не существует. Это оператор языка С++ и о нем дальше, когда будет переход к С++. Видите, как важно разделять эти два языка и учить их последовательно: сначала Си, а потом С++.
@@selfedu_rus Я понимаю, что это части разных языков. Просто задумываюсь о том, актуально ли сейчас вообще ещё учить именно язык С, если в С++ всё работает намного стабильнее. Мой компилятор в Visual Studio уже много команд из Си даже не распознает или пишет "unsafe". Результаты работы malloc и calloc только в указатели типа void* давал записывать. Интересно услышать Ваше мнение
@@selfedu_rus И ещё хотел спросить, есть ли у Вас на канале реализация бинарного дерева на С++. Потому что я только на Python нашел.
в чём прикол calloc, если есть realloc?
Я хочу засунуть слово в переменную :ЕГГОГ
Я хочу засунуть данные в переменную:ЕГГОГ
Какой хмырь придумал эти типы данных и почему кислое нельзя превратить в длинное на ходу
Какой извращенец подумал и сказал...ооо да мне нравится ставить точку с запятой после каждой строчки мм как удобно
2д массив нельзя впихнуть в 3д массив
Весь язык пропитан какими то заборами
Так нельзя Так не делай Так я не могу
Аж моча закипает когда я вижу этот синтаксис там больше слов чем самой сути кода ёлы палы
И не говори брат
Српчно курить мануалыюю Ошибка на ошибке
Добрый день! Спасибо за урок! Переписал Вашу программу как у Вас было написано, но у меня проверка ругалась ( на size_t) и не хотела компилировать. После того как поменял на int и поставил фигурные скобки в строке 37 все заработало. Я новичок и просто интересно почему так у меня получилось? Проверял так: gcc -Wall -Werror -Wextra -o ucheba ucheba.c
size_t - это переопределенный целочисленный тип (прописывается в одном из заголовочных файлов, вроде, stddef.h). Его определение выглядит примерно так:
typedef unsigned int size_t;
@@selfedu_rus ок. Спасибо большое за ответ!