Тёмный
No video :(

Техника безопасности при работе с памятью в Си 

Тимофей Хирьянов
Подписаться 353 тыс.
Просмотров 34 тыс.
50% 1

Ошибки работы с памятью в Си: Segmentation fault, Memory leak.
Инициализация указателей: NULL.
Проверка корректности адреса.
Ответственность за освобождение памяти.
Курс молодого бойца по информатике (Язык Си).
cs.mipt.ru/c_intro

Опубликовано:

 

14 авг 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 57   
@bishop_ru6767
@bishop_ru6767 4 года назад
Благодарю за лекцию + с уважением!
@SloRez118
@SloRez118 Год назад
Спасибо! за столь огромный труд! После использования функций gets() или указателя без инициализации или массива на стеке, или гарантия доступа за границы массива (*(name - 1) и *(name+sizeof(name)+1). ) программирование на языки Си это нервный тик при объявлении объектов памяти. шаг -> расстрел.
@sergeigrigorev4427
@sergeigrigorev4427 2 года назад
Большое спасибо за ваши лекции!
@user-qv2ri8tc7p
@user-qv2ri8tc7p 5 месяцев назад
спасибо за курс!
@andreivoronin8636
@andreivoronin8636 2 года назад
Полезная и довольно редкая информация! Спасибо!
@ArtemMELNYK
@ArtemMELNYK 3 года назад
Это дар, рассказать интересно и понятно, профессионально и запоминаемо.
@Ma_X64
@Ma_X64 4 года назад
Я люблю Си. В том числе, за большие проблемы при работе с памятью. Потому что -- кому проблемы, а кому -- фишечки.
@garrygaller2853
@garrygaller2853 4 года назад
Фишечки тому, для кого проггерство - игрушечки. Для тех же, кто пишет оборонное, медицинское и космическое ПО - это ПРОБЛЕМЫ.
@Ma_X64
@Ma_X64 4 года назад
@@garrygaller2853 какие далеко идущие выводы из ни}{✓я, однако! Больше 50 процентов действующего медицинского и, особенно, военного ПО, написано во времена, когда и Си считался слишком высокоуровневым для таких задач. И люди, пишущие подобное ПО, скорей всего пошлют вас лесом, если вы начнёте втирать им эту дичь про проблемы языка. Это все равно, что столяру вы начнёте рассказывать, какие ужасные проблемы у вот этого молотка или вот этой циркулярной пилы! Она ведь очень опасна -- можно и руку себе отрезать! Все эти современные тенденции создания языков, которые пытаются обезопасить идиота от его собственного мозга, родились из-за бума электронной и IT индустрии, в результате которого программистом быть стало тупо модно, и в программисты повалили все, кому не лень. Люди на своем-то родном языке, зачастую, мысли выражать не умеют, а лезут на ЯП выражаться и ещё других потом учить начинают.
@user-cu9wl3dn5j
@user-cu9wl3dn5j 4 года назад
Особенно интересно хакерам, когда происходит переполнение буфера или проблемы с памятью)))
@Ma_X64
@Ma_X64 4 года назад
@@user-cu9wl3dn5j Выделил память -- отдай обратно. Следи за границами. Я понимаю, что сейчас уже в микроконтроллеры джава-машину суют, но тогда, может, будем на велосипед ставить турбовентиляторный двигатель, полный комплект средств безопасности, двух пилотов (ну ладно, одного)... А потом получаем программистов, которые за деньги пишут код, но не могут даже в битовые операции -- тупо не знают, как это. (Это вот прям совсем не шутка и не преувеличение) Потому что низззяяяя! Вдруг чего-нибудь не так там сделаешь! Когда я учился, так же пугали ассемблером. Мол, там же можно прям в регистры процессора писать и память портить, как вздумается. А еще, о УЖАС!, там нужно руками контекст в стеке сохранять -- это ж сколько напартачить можно!
@garrygaller2853
@garrygaller2853 4 года назад
@@Ma_X64" И люди, пишущие подобное ПО, скорей всего пошлют вас лесом" Далеко идущее заявление. Потому что среди специалистов как раз таки есть понимание всех проблем языка и необходимости их исправлять. Так что скорей пошлют тебя, горе-оптимиста. Все остальное в твоем посте - бессмысленная дичь. Новые языки создаются потому что таково требование времени и этого нельзя избежать.
@lelelele1746
@lelelele1746 11 месяцев назад
Огромное спасибо, Тимофей Федорович! Я прошел этот курс.
@_klim4204
@_klim4204 2 года назад
Мне 12 лет, я хочу научится работать с памятью в Си, вот, ищу Инфу. Наткнулся на этот канал, надо учитывать что здесь я и научился языку Си
@StepanChuevYT
@StepanChuevYT 2 года назад
Тоже самое!!!
@_klim4204
@_klim4204 2 года назад
@@StepanChuevYT а тебе сколько лет?
@StepanChuevYT
@StepanChuevYT 2 года назад
@@_klim4204 13
@user-ve9gq9bn1r
@user-ve9gq9bn1r 4 года назад
В плейлисте курса не хватает видео Переменные в языке С
@user-li3tg7zd7x
@user-li3tg7zd7x Год назад
спасибо большое за ваши видео
@gohardgomykhailovarenytsia9006
здравствуйте Тимофей! Благодарю вас за чудесный курс (стдент МГТУ). Появился вопрос про ситуацию на 12ой минуте видео. Если в цикле перевыделять память одной и той же переменной, то как ее потом освободить? Я считал, что в таком случае результат будет такой же, как у функции реаллок и у указателя будет меняться размер принадлежащего ему пространства памяти, и использование одного free будет достаточно.
@svlapin
@svlapin 4 года назад
Дело в том, что неважно, в какую переменную кладется результат malloc() - каждый раз выделяется новый блок памяти, и переменная "p" перезаписывается, чтобы указывать на этот новый блок. Таким образом, по завершении цикла "p" указывает на последний выделенный блок, а все блоки, выделенные до этого - потеряны - указателей на них нет.
@maratimus
@maratimus 5 лет назад
Garbage collector жрет много ресурсов и эффективность у него не стопроцентная, всегда будет утечка, лучше один раз написать правильно на С, чем всё время коллектору анализировать код и память. Поэтому С форевер.
@Ma_X64
@Ma_X64 4 года назад
Воистину!
@programer8
@programer8 3 года назад
@@Ma_X64 C will never die
@orangesoupd
@orangesoupd 3 года назад
Лучше совмещать приятное с полезным и писать только некоторые части программ на языках типа C, а остальные - хоть на python.
@stdany5163
@stdany5163 3 года назад
А какие варианты есть у strdup кроме как сделать аллокацию? Использовать alloca? В общем не понял проблему
@evgeniygazetdinov1620
@evgeniygazetdinov1620 4 года назад
Тимофей Федорович наше все!
@yuliyacher67
@yuliyacher67 Год назад
Спасибо!
@dimalink4486
@dimalink4486 Год назад
Вот как раз думал повторить СИ. Как раз с памятью что там. Начал с этого вопроса. И как то идея повторить СИ. Раньше мне как-то ума не хватало на программирование. То есть прошел курс, понял. Но как то сверхсложным все казалось. Так что вот теперь надо еще раз. Кстати может повторить прямо. По урокам, думаю. Это СИ. Раньше, я его 1 раз быстро минимум какой то прошел и сразу на СИ++. Трудно, страшно. Поэтому и рад был что с СИ там за уроков 7 что ли... Быстро разделался то же по видел тогда учил. Но тогда - это первый раз. Без всякой специальной подготовки. Поэтому конечно, это был АД для меня. Мой МОЗГ не был готов к такому. Но усвоить и пройти удалось. Думаю теперь еще раз! Повторить все.
@user-mm5ln4qh5q
@user-mm5ln4qh5q Год назад
Для начала следует повторить русский язык
@pro100SOm
@pro100SOm 6 лет назад
Очень странно... числа Вы сравниваете с 0, хотя с ними разночтений не бывает. А вот указатели лучше таки сравнивать с константой NULL - может быть в некоторых компиляторах не совсем ожидаемая реакция на попытку неявного преобразования...
@tkhirianov
@tkhirianov 6 лет назад
Александр, не понял вашего замечания. Уточните, пожалуйста, с меткой времени.
@pro100SOm
@pro100SOm 6 лет назад
6:54 - Вы убиваете сравнение с NULL. При этом в других роликах сравниваете числа с нулем. Это не замечание, а скорее удивление. Поведение преобразование чисел к булевым однозначно: не ноль = тру, ноль = фолс Кажется, Страуструп писал о том, что поведение неявного преобразования указателей к булевому не столь однозначно... но может это на каком-нить семинаре мейл.ру или яндекса звучало... точно не скажу. ЗЫ я сам тоже в учебных примерах не сравниваю с NULL... исключительно из соображений "красоты" :))
@istra3265
@istra3265 5 лет назад
@@tkhirianov у вас нет ли дальнейших курсов? может платных, чтоб получить знания, достаточные для работы программистом без официального диплома?
@shurakm
@shurakm 4 года назад
@@istra3265 NULL это макрос #define NULL ((void*)0), вобщем всегда 0
@7qim
@7qim 2 года назад
@@shurakm Замечание вполне дельное, поскольку нужно изначально формировать правильный подход, код должен быть осмысленным и единообразным, а не просто работать, тогда это не только облегчит его чтение, понимание и отладку, но и не приведёт к непредсказуемым ошибкам при переносе на другую платформу или другой язык, где NULL вполне может быть, скажем, -1. То есть нужно "NULL" воспринимать не как "0", а как значение переменной по умолчанию, иначе вообще забыть про "NULL" и везде писать "0", но большое количество "магических чисел" в коде может угнетать и резко снизить его понятность спустя годы.
@Al-en6nj
@Al-en6nj 2 года назад
так, ачто дальше, я могу работать?
@sergioostanioni5390
@sergioostanioni5390 3 года назад
У первой лекции в 11 раз больше просмотров )
@fish9370
@fish9370 5 лет назад
А stack overflow, buffer overflow Вы не относите к проблемам работы с памятью? Ведь большинство уязвимостей строится именно на этих ошибках. Странно, что тут ничего об этом не сказано
@gpvphoobastankvarerera6313
@gpvphoobastankvarerera6313 5 лет назад
как бы это очевидные вещи и можно сравнить с ситуацией записи лонгового числа в интовую переменную
@tema_skakun
@tema_skakun 3 года назад
ваши примеры были рассмотрены в видео "переполнение и ошибки при работе с целыми типами"
@alexjakcson14
@alexjakcson14 3 года назад
Хороший пример ТЕЛЕГРАММ. течет на всех системах )))))
@romiro9541
@romiro9541 3 года назад
100мб в ОЗУ - не утечка, поставьте пожалуйста хотя бы 4гб озу
@RobotN001
@RobotN001 Год назад
может он течёт из-за QT ?
@onaecO
@onaecO Год назад
😍
@nicholasspezza9449
@nicholasspezza9449 6 месяцев назад
и где следующее видео? 🧐
@cavdputeam
@cavdputeam Год назад
1000й )))
Далее
Редакция. News: 129-я неделя
49:53
Просмотров 2 млн
Функции в языке Си
27:17
Просмотров 44 тыс.
Редакция. News: 129-я неделя
49:53
Просмотров 2 млн