Ошибки работы с памятью в Си: Segmentation fault, Memory leak. Инициализация указателей: NULL. Проверка корректности адреса. Ответственность за освобождение памяти. Курс молодого бойца по информатике (Язык Си). cs.mipt.ru/c_intro
Пікірлер: 57
@bishop_ru67674 жыл бұрын
Благодарю за лекцию + с уважением!
@ArtemMELNYK2 жыл бұрын
Это дар, рассказать интересно и понятно, профессионально и запоминаемо.
@andreivoronin8636 Жыл бұрын
Полезная и довольно редкая информация! Спасибо!
@SloRez118 Жыл бұрын
Спасибо! за столь огромный труд! После использования функций gets() или указателя без инициализации или массива на стеке, или гарантия доступа за границы массива (*(name - 1) и *(name+sizeof(name)+1). ) программирование на языки Си это нервный тик при объявлении объектов памяти. шаг -> расстрел.
@sergeigrigorev44272 жыл бұрын
Большое спасибо за ваши лекции!
@lelelele17468 ай бұрын
Огромное спасибо, Тимофей Федорович! Я прошел этот курс.
@user-qv2ri8tc7p2 ай бұрын
спасибо за курс!
@user-li3tg7zd7x11 ай бұрын
спасибо большое за ваши видео
@yuliyacher67 Жыл бұрын
Спасибо!
@stdany51633 жыл бұрын
А какие варианты есть у strdup кроме как сделать аллокацию? Использовать alloca? В общем не понял проблему
@Ma_X644 жыл бұрын
Я люблю Си. В том числе, за большие проблемы при работе с памятью. Потому что -- кому проблемы, а кому -- фишечки.
@garrygaller28533 жыл бұрын
Фишечки тому, для кого проггерство - игрушечки. Для тех же, кто пишет оборонное, медицинское и космическое ПО - это ПРОБЛЕМЫ.
@Ma_X643 жыл бұрын
@@garrygaller2853 какие далеко идущие выводы из ни}{✓я, однако! Больше 50 процентов действующего медицинского и, особенно, военного ПО, написано во времена, когда и Си считался слишком высокоуровневым для таких задач. И люди, пишущие подобное ПО, скорей всего пошлют вас лесом, если вы начнёте втирать им эту дичь про проблемы языка. Это все равно, что столяру вы начнёте рассказывать, какие ужасные проблемы у вот этого молотка или вот этой циркулярной пилы! Она ведь очень опасна -- можно и руку себе отрезать! Все эти современные тенденции создания языков, которые пытаются обезопасить идиота от его собственного мозга, родились из-за бума электронной и IT индустрии, в результате которого программистом быть стало тупо модно, и в программисты повалили все, кому не лень. Люди на своем-то родном языке, зачастую, мысли выражать не умеют, а лезут на ЯП выражаться и ещё других потом учить начинают.
@user-cu9wl3dn5j3 жыл бұрын
Особенно интересно хакерам, когда происходит переполнение буфера или проблемы с памятью)))
@Ma_X643 жыл бұрын
@@user-cu9wl3dn5j Выделил память -- отдай обратно. Следи за границами. Я понимаю, что сейчас уже в микроконтроллеры джава-машину суют, но тогда, может, будем на велосипед ставить турбовентиляторный двигатель, полный комплект средств безопасности, двух пилотов (ну ладно, одного)... А потом получаем программистов, которые за деньги пишут код, но не могут даже в битовые операции -- тупо не знают, как это. (Это вот прям совсем не шутка и не преувеличение) Потому что низззяяяя! Вдруг чего-нибудь не так там сделаешь! Когда я учился, так же пугали ассемблером. Мол, там же можно прям в регистры процессора писать и память портить, как вздумается. А еще, о УЖАС!, там нужно руками контекст в стеке сохранять -- это ж сколько напартачить можно!
@garrygaller28533 жыл бұрын
@@Ma_X64" И люди, пишущие подобное ПО, скорей всего пошлют вас лесом" Далеко идущее заявление. Потому что среди специалистов как раз таки есть понимание всех проблем языка и необходимости их исправлять. Так что скорей пошлют тебя, горе-оптимиста. Все остальное в твоем посте - бессмысленная дичь. Новые языки создаются потому что таково требование времени и этого нельзя избежать.
@evgeniygazetdinov16204 жыл бұрын
Тимофей Федорович наше все!
@user-ve9gq9bn1r4 жыл бұрын
В плейлисте курса не хватает видео Переменные в языке С
@_klim42042 жыл бұрын
Мне 12 лет, я хочу научится работать с памятью в Си, вот, ищу Инфу. Наткнулся на этот канал, надо учитывать что здесь я и научился языку Си
@StepanChuevYT2 жыл бұрын
Тоже самое!!!
@_klim42042 жыл бұрын
@@StepanChuevYT а тебе сколько лет?
@StepanChuevYT2 жыл бұрын
@@_klim4204 13
@gohardgomykhailovarenytsia90065 жыл бұрын
здравствуйте Тимофей! Благодарю вас за чудесный курс (стдент МГТУ). Появился вопрос про ситуацию на 12ой минуте видео. Если в цикле перевыделять память одной и той же переменной, то как ее потом освободить? Я считал, что в таком случае результат будет такой же, как у функции реаллок и у указателя будет меняться размер принадлежащего ему пространства памяти, и использование одного free будет достаточно.
@svlapin4 жыл бұрын
Дело в том, что неважно, в какую переменную кладется результат malloc() - каждый раз выделяется новый блок памяти, и переменная "p" перезаписывается, чтобы указывать на этот новый блок. Таким образом, по завершении цикла "p" указывает на последний выделенный блок, а все блоки, выделенные до этого - потеряны - указателей на них нет.
@Al-en6nj Жыл бұрын
так, ачто дальше, я могу работать?
@sergioostanioni53903 жыл бұрын
У первой лекции в 11 раз больше просмотров )
@maratimus5 жыл бұрын
Garbage collector жрет много ресурсов и эффективность у него не стопроцентная, всегда будет утечка, лучше один раз написать правильно на С, чем всё время коллектору анализировать код и память. Поэтому С форевер.
@Ma_X644 жыл бұрын
Воистину!
@programer83 жыл бұрын
@@Ma_X64 C will never die
@orangesoupd2 жыл бұрын
Лучше совмещать приятное с полезным и писать только некоторые части программ на языках типа C, а остальные - хоть на python.
@onaecO Жыл бұрын
😍
@dimalink4486 Жыл бұрын
Вот как раз думал повторить СИ. Как раз с памятью что там. Начал с этого вопроса. И как то идея повторить СИ. Раньше мне как-то ума не хватало на программирование. То есть прошел курс, понял. Но как то сверхсложным все казалось. Так что вот теперь надо еще раз. Кстати может повторить прямо. По урокам, думаю. Это СИ. Раньше, я его 1 раз быстро минимум какой то прошел и сразу на СИ++. Трудно, страшно. Поэтому и рад был что с СИ там за уроков 7 что ли... Быстро разделался то же по видел тогда учил. Но тогда - это первый раз. Без всякой специальной подготовки. Поэтому конечно, это был АД для меня. Мой МОЗГ не был готов к такому. Но усвоить и пройти удалось. Думаю теперь еще раз! Повторить все.
@user-mm5ln4qh5q9 ай бұрын
Для начала следует повторить русский язык
@fish93705 жыл бұрын
А stack overflow, buffer overflow Вы не относите к проблемам работы с памятью? Ведь большинство уязвимостей строится именно на этих ошибках. Странно, что тут ничего об этом не сказано
@gpvphoobastankvarerera63135 жыл бұрын
как бы это очевидные вещи и можно сравнить с ситуацией записи лонгового числа в интовую переменную
@tema_skakun2 жыл бұрын
ваши примеры были рассмотрены в видео "переполнение и ошибки при работе с целыми типами"
@pro100SOm5 жыл бұрын
Очень странно... числа Вы сравниваете с 0, хотя с ними разночтений не бывает. А вот указатели лучше таки сравнивать с константой NULL - может быть в некоторых компиляторах не совсем ожидаемая реакция на попытку неявного преобразования...
@tkhirianov5 жыл бұрын
Александр, не понял вашего замечания. Уточните, пожалуйста, с меткой времени.
@pro100SOm5 жыл бұрын
6:54 - Вы убиваете сравнение с NULL. При этом в других роликах сравниваете числа с нулем. Это не замечание, а скорее удивление. Поведение преобразование чисел к булевым однозначно: не ноль = тру, ноль = фолс Кажется, Страуструп писал о том, что поведение неявного преобразования указателей к булевому не столь однозначно... но может это на каком-нить семинаре мейл.ру или яндекса звучало... точно не скажу. ЗЫ я сам тоже в учебных примерах не сравниваю с NULL... исключительно из соображений "красоты" :))
@istra32655 жыл бұрын
@@tkhirianov у вас нет ли дальнейших курсов? может платных, чтоб получить знания, достаточные для работы программистом без официального диплома?
@shurakm4 жыл бұрын
@@istra3265 NULL это макрос #define NULL ((void*)0), вобщем всегда 0
@7qim2 жыл бұрын
@@shurakm Замечание вполне дельное, поскольку нужно изначально формировать правильный подход, код должен быть осмысленным и единообразным, а не просто работать, тогда это не только облегчит его чтение, понимание и отладку, но и не приведёт к непредсказуемым ошибкам при переносе на другую платформу или другой язык, где NULL вполне может быть, скажем, -1. То есть нужно "NULL" воспринимать не как "0", а как значение переменной по умолчанию, иначе вообще забыть про "NULL" и везде писать "0", но большое количество "магических чисел" в коде может угнетать и резко снизить его понятность спустя годы.
@alexjakcson143 жыл бұрын
Хороший пример ТЕЛЕГРАММ. течет на всех системах )))))
@romiro95413 жыл бұрын
100мб в ОЗУ - не утечка, поставьте пожалуйста хотя бы 4гб озу