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

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

Комментарии • 57

  • @bishop_ru6767
    @bishop_ru6767 4 года назад +14

    Благодарю за лекцию + с уважением!

  • @user-qv2ri8tc7p
    @user-qv2ri8tc7p 2 месяца назад +1

    спасибо за курс!

  • @SloRez118
    @SloRez118 Год назад

    Спасибо! за столь огромный труд!
    После использования функций gets() или указателя без инициализации или массива на стеке, или гарантия доступа за границы массива (*(name - 1) и *(name+sizeof(name)+1). ) программирование на языки Си это нервный тик при объявлении объектов памяти.
    шаг -> расстрел.

  • @ArtemMELNYK
    @ArtemMELNYK 2 года назад

    Это дар, рассказать интересно и понятно, профессионально и запоминаемо.

  • @andreivoronin8636
    @andreivoronin8636 Год назад +1

    Полезная и довольно редкая информация! Спасибо!

  • @sergeigrigorev4427
    @sergeigrigorev4427 2 года назад +4

    Большое спасибо за ваши лекции!

  • @user-li3tg7zd7x
    @user-li3tg7zd7x Год назад

    спасибо большое за ваши видео

  • @stdany5163
    @stdany5163 3 года назад +1

    А какие варианты есть у strdup кроме как сделать аллокацию?
    Использовать alloca? В общем не понял проблему

  • @Ma_X64
    @Ma_X64 4 года назад +14

    Я люблю Си. В том числе, за большие проблемы при работе с памятью. Потому что -- кому проблемы, а кому -- фишечки.

    • @garrygaller2853
      @garrygaller2853 3 года назад

      Фишечки тому, для кого проггерство - игрушечки. Для тех же, кто пишет оборонное, медицинское и космическое ПО - это ПРОБЛЕМЫ.

    • @Ma_X64
      @Ma_X64 3 года назад +16

      @@garrygaller2853 какие далеко идущие выводы из ни}{✓я, однако! Больше 50 процентов действующего медицинского и, особенно, военного ПО, написано во времена, когда и Си считался слишком высокоуровневым для таких задач. И люди, пишущие подобное ПО, скорей всего пошлют вас лесом, если вы начнёте втирать им эту дичь про проблемы языка. Это все равно, что столяру вы начнёте рассказывать, какие ужасные проблемы у вот этого молотка или вот этой циркулярной пилы! Она ведь очень опасна -- можно и руку себе отрезать! Все эти современные тенденции создания языков, которые пытаются обезопасить идиота от его собственного мозга, родились из-за бума электронной и IT индустрии, в результате которого программистом быть стало тупо модно, и в программисты повалили все, кому не лень. Люди на своем-то родном языке, зачастую, мысли выражать не умеют, а лезут на ЯП выражаться и ещё других потом учить начинают.

    • @user-cu9wl3dn5j
      @user-cu9wl3dn5j 3 года назад

      Особенно интересно хакерам, когда происходит переполнение буфера или проблемы с памятью)))

    • @Ma_X64
      @Ma_X64 3 года назад

      @@user-cu9wl3dn5j Выделил память -- отдай обратно. Следи за границами. Я понимаю, что сейчас уже в микроконтроллеры джава-машину суют, но тогда, может, будем на велосипед ставить турбовентиляторный двигатель, полный комплект средств безопасности, двух пилотов (ну ладно, одного)... А потом получаем программистов, которые за деньги пишут код, но не могут даже в битовые операции -- тупо не знают, как это. (Это вот прям совсем не шутка и не преувеличение) Потому что низззяяяя! Вдруг чего-нибудь не так там сделаешь! Когда я учился, так же пугали ассемблером. Мол, там же можно прям в регистры процессора писать и память портить, как вздумается. А еще, о УЖАС!, там нужно руками контекст в стеке сохранять -- это ж сколько напартачить можно!

    • @garrygaller2853
      @garrygaller2853 3 года назад

      @@Ma_X64" И люди, пишущие подобное ПО, скорей всего пошлют вас лесом" Далеко идущее заявление. Потому что среди специалистов как раз таки есть понимание всех проблем языка и необходимости их исправлять. Так что скорей пошлют тебя, горе-оптимиста. Все остальное в твоем посте - бессмысленная дичь. Новые языки создаются потому что таково требование времени и этого нельзя избежать.

  • @yuliyacher67
    @yuliyacher67 Год назад

    Спасибо!

  • @evgeniygazetdinov1620
    @evgeniygazetdinov1620 4 года назад +2

    Тимофей Федорович наше все!

  • @lelelele1746
    @lelelele1746 9 месяцев назад

    Огромное спасибо, Тимофей Федорович! Я прошел этот курс.

  • @user-ve9gq9bn1r
    @user-ve9gq9bn1r 4 года назад +6

    В плейлисте курса не хватает видео Переменные в языке С

  • @gohardgomykhailovarenytsia9006
    @gohardgomykhailovarenytsia9006 5 лет назад +6

    здравствуйте Тимофей! Благодарю вас за чудесный курс (стдент МГТУ). Появился вопрос про ситуацию на 12ой минуте видео. Если в цикле перевыделять память одной и той же переменной, то как ее потом освободить?
    Я считал, что в таком случае результат будет такой же, как у функции реаллок и у указателя будет меняться размер принадлежащего ему пространства памяти, и использование одного free будет достаточно.

    • @svlapin
      @svlapin 4 года назад +8

      Дело в том, что неважно, в какую переменную кладется результат malloc() - каждый раз выделяется новый блок памяти, и переменная "p" перезаписывается, чтобы указывать на этот новый блок. Таким образом, по завершении цикла "p" указывает на последний выделенный блок, а все блоки, выделенные до этого - потеряны - указателей на них нет.

  • @_klim4204
    @_klim4204 2 года назад +2

    Мне 12 лет, я хочу научится работать с памятью в Си, вот, ищу Инфу. Наткнулся на этот канал, надо учитывать что здесь я и научился языку Си

    • @StepanChuevYT
      @StepanChuevYT 2 года назад

      Тоже самое!!!

    • @_klim4204
      @_klim4204 2 года назад

      @@StepanChuevYT а тебе сколько лет?

    • @StepanChuevYT
      @StepanChuevYT 2 года назад

      @@_klim4204 13

  • @fish9370
    @fish9370 5 лет назад +2

    А stack overflow, buffer overflow Вы не относите к проблемам работы с памятью? Ведь большинство уязвимостей строится именно на этих ошибках. Странно, что тут ничего об этом не сказано

    • @gpvphoobastankvarerera6313
      @gpvphoobastankvarerera6313 5 лет назад +1

      как бы это очевидные вещи и можно сравнить с ситуацией записи лонгового числа в интовую переменную

    • @tema_skakun
      @tema_skakun 3 года назад

      ваши примеры были рассмотрены в видео "переполнение и ошибки при работе с целыми типами"

  • @Al-en6nj
    @Al-en6nj Год назад

    так, ачто дальше, я могу работать?

  • @onaecO
    @onaecO Год назад

    😍

  • @maratimus
    @maratimus 5 лет назад +16

    Garbage collector жрет много ресурсов и эффективность у него не стопроцентная, всегда будет утечка, лучше один раз написать правильно на С, чем всё время коллектору анализировать код и память. Поэтому С форевер.

    • @Ma_X64
      @Ma_X64 4 года назад

      Воистину!

    • @programer8
      @programer8 3 года назад +1

      @@Ma_X64 C will never die

    • @orangesoupd
      @orangesoupd 2 года назад

      Лучше совмещать приятное с полезным и писать только некоторые части программ на языках типа C, а остальные - хоть на python.

  • @pro100SOm
    @pro100SOm 5 лет назад +1

    Очень странно... числа Вы сравниваете с 0, хотя с ними разночтений не бывает. А вот указатели лучше таки сравнивать с константой NULL - может быть в некоторых компиляторах не совсем ожидаемая реакция на попытку неявного преобразования...

    • @tkhirianov
      @tkhirianov  5 лет назад +1

      Александр, не понял вашего замечания. Уточните, пожалуйста, с меткой времени.

    • @pro100SOm
      @pro100SOm 5 лет назад

      6:54 - Вы убиваете сравнение с NULL. При этом в других роликах сравниваете числа с нулем.
      Это не замечание, а скорее удивление. Поведение преобразование чисел к булевым однозначно: не ноль = тру, ноль = фолс
      Кажется, Страуструп писал о том, что поведение неявного преобразования указателей к булевому не столь однозначно... но может это на каком-нить семинаре мейл.ру или яндекса звучало... точно не скажу.
      ЗЫ я сам тоже в учебных примерах не сравниваю с NULL... исключительно из соображений "красоты" :))

    • @istra3265
      @istra3265 5 лет назад +4

      @@tkhirianov у вас нет ли дальнейших курсов? может платных, чтоб получить знания, достаточные для работы программистом без официального диплома?

    • @shurakm
      @shurakm 4 года назад

      @@istra3265 NULL это макрос #define NULL ((void*)0), вобщем всегда 0

    • @7qim
      @7qim 2 года назад

      @@shurakm Замечание вполне дельное, поскольку нужно изначально формировать правильный подход, код должен быть осмысленным и единообразным, а не просто работать, тогда это не только облегчит его чтение, понимание и отладку, но и не приведёт к непредсказуемым ошибкам при переносе на другую платформу или другой язык, где NULL вполне может быть, скажем, -1.
      То есть нужно "NULL" воспринимать не как "0", а как значение переменной по умолчанию, иначе вообще забыть про "NULL" и везде писать "0", но большое количество "магических чисел" в коде может угнетать и резко снизить его понятность спустя годы.

  • @sergioostanioni5390
    @sergioostanioni5390 3 года назад +1

    У первой лекции в 11 раз больше просмотров )

  • @dimalink4486
    @dimalink4486 Год назад +1

    Вот как раз думал повторить СИ. Как раз с памятью что там. Начал с этого вопроса. И как то идея повторить СИ.
    Раньше мне как-то ума не хватало на программирование. То есть прошел курс, понял. Но как то сверхсложным все казалось. Так что вот теперь надо еще раз. Кстати может повторить прямо. По урокам, думаю. Это СИ. Раньше, я его 1 раз быстро минимум какой то прошел и сразу на СИ++. Трудно, страшно. Поэтому и рад был что с СИ там за уроков 7 что ли... Быстро разделался то же по видел тогда учил. Но тогда - это первый раз. Без всякой специальной подготовки. Поэтому конечно, это был АД для меня. Мой МОЗГ не был готов к такому. Но усвоить и пройти удалось.
    Думаю теперь еще раз! Повторить все.

    • @user-mm5ln4qh5q
      @user-mm5ln4qh5q 10 месяцев назад

      Для начала следует повторить русский язык

  • @alexjakcson14
    @alexjakcson14 3 года назад +2

    Хороший пример ТЕЛЕГРАММ. течет на всех системах )))))

    • @romiro9541
      @romiro9541 3 года назад +1

      100мб в ОЗУ - не утечка, поставьте пожалуйста хотя бы 4гб озу

    • @RobotN001
      @RobotN001 10 месяцев назад

      может он течёт из-за QT ?

  • @nicholasspezza9449
    @nicholasspezza9449 4 месяца назад

    и где следующее видео? 🧐

  • @cavdputeam
    @cavdputeam Год назад

    1000й )))