Улучшаем и усложняем C++ код: функции, исключения, ranges и корутины

2024 ж. 1 Мам.
8 722 Рет қаралды

20 марта 2024 компания YADRO провела большой C++ митап в Санкт-Петербурге. Константин Владимиров из Syntacore рассказал, какая стоимость абстракции принципиально устранима (например, грамотным использованием или улучшением компилятора), а какая неизбежна.
00:00 - представление докладчика
00:45 - самый простой механизм абстракции: исправляем вызов функции, и наоборот
06:00 - проблемы при отсутствии инлайна
07:10 - бенчмарки и стоимость микроархитектуры
08:30 - компилятор и его влияние на стоимость абстракции
12:40 - разбираемся с виртуальными функциями, их проблемами и оптимизацией стоимости
22:00 - исключения: пожалуй, самый критикуемый механизм C++
28:50 - почему исключения не бесплатны, даже если их не кидать
32:45 - корутины: замеры на базовом примере и не только
38:40 - почему оптимизации корутин сильно зависят от компилятора
39:35 - пробуем разные версии ranges и... проигрываем
46:00 - как повторить исследование Константина
47:40 - вопросы докладчику
Слайды drive.yadro.com/s/NTy3jDHtsLe...

Пікірлер
  • Однозначно плюсую за очередную лекцию.

    @AlexisVaBel@AlexisVaBel20 күн бұрын
  • Спасибо за доклад, Константин как всегда рассказывает живо и интересно.

    @SmoukingMouse@SmoukingMouse12 күн бұрын
  • аплодирую стоя (сидя) -- балдежно балдежный доклад!!! я постоянно запрашиваю у людей, которые пишут на си, ответы почему они считают до сих пор, что си++ медленнее... ну и ессесна не получаю никаких доводов... тут же просто разнос от авторитетного учителя.

    @safocl9768@safocl976820 күн бұрын
    • В С++ много лишнего в библиотеках, все что есть в библиотеках С++, можно реализовать во первых быстрее на С (при знаниях соответствующих), во вторых не надо отслеживать что в этих библиотеках есть лишнее, что не использует программа, а так да, если грамотно писать на С++ и отслеживать все лишнее, убирая это, то С++ не медленнее. P.S. Это лично мое мнение, возможно не прав.

      @nullptr_or_null8301@nullptr_or_null830120 күн бұрын
    • ​​@@nullptr_or_null8301Так что не используешь в итоговый бинарь не попадает, что в Си, что в Си++. Ну максимум оверхеды на время сборки неиспользуемых файлов, но на фоне как минимум удобно возвращаемых значений из функций и всяких скоуп-гардов, что не дает утечь, вообще не понятно, что там такого лишнего. Ну а если вы придумаете как реализовать qsort на си быстрее чем текущая реализация на c++, пожалуйста занесите её в стд

      @isadora-6th@isadora-6th19 күн бұрын
    • @@nullptr_or_null8301 если ты про std библиотеку, то её быстрее не напишешь, там шарящие люди всё уже давно оптимизировали(проверенно)

      @Kerojey@Kerojey17 күн бұрын
    • ​@@nullptr_or_null8301 В том то и дело что плюсы не то что медленнее С, а в некоторых случаях быстрее, например инлайн предикатов.

      @TheKozladoy@TheKozladoy14 күн бұрын
  • Как всегда интересно, увлекательно, познавательно. Спасибо за лекцию.

    @KIR_Engineer@KIR_Engineer20 күн бұрын
  • Очень познавательный доклад, глубокие темы. Спасибо большое!

    @user-sf5wt4lf6i@user-sf5wt4lf6i16 күн бұрын
  • Хороший доклад, спасибо

    @evgeniybeschastnov4627@evgeniybeschastnov462715 күн бұрын
  • Каждый подобный доклад с конфы по C++ выглядит как сверхусилия для движения в совершенно ошибочном направлении: проблемы, вызванные C++ исправляются с помощью более сложных средств всё того же C++, что привносит потенциально более сложные и глубокие проблемы. Но докладчик очень хорош и в плане подачи, и структуры доклада 👍

    @linkernick5379@linkernick537917 күн бұрын
    • C++ -- это разрастающаяся кряхтящая матка ксеноморфа, которая вот-вот породит яйцо, внутри которого будет свежий язык со всеми решёнными проблемами, но ждать осталось ещё лет 20. Подождём...

      @eugene_martein@eugene_martein9 күн бұрын
  • вы лучший. я так поинмаю нас впереди ожидает серия выпусков на данную тематику. было бы очень интересно.

    @MikhailGoncharov-tl4cr@MikhailGoncharov-tl4cr18 күн бұрын
  • 27:22 -- я вот думаю, что если вылетело исключение (при правильном их использовании ессесна) -- то уже не стоит думать про производительность и сколько времени потрачено, поскольку программа совершила "поворот нетуда" (некорректную работу)...

    @safocl9768@safocl976820 күн бұрын
  • Я доклад господина Русяева не видел, но то, что исключения не бесплатны, даже если их не кидать - не сказать, что очень глубокая мысль. Не бесплатны по сравнению с чем? С отсутствием проверки ошибок? Любая функциональность не бесплатна, если её использовать. Главное-то не то, что "не бесплатно", а то, что программа с исключениями дешевле, чем программа с проверками кодов возврата.

    @vr360_progress4@vr360_progress419 күн бұрын
    • Небесплатны в сравнении с проверкой кодов возврата или ранним return.

      @linkernick5379@linkernick537916 күн бұрын
    • @@linkernick5379 То есть, проверка кодов возврата бесплатна? Вроде бы в этом самом докладе показано, что коды возврата дороже (если вы не helloworld пишете). Ранний return тоже сам по себе не появится, для того, чтобы его сделать, надо проверить код возврата - и так на всех 15 уровнях вложения.

      @vr360_progress4@vr360_progress416 күн бұрын
  • А разве не переменная является самым простым механизмом абстракции? Это же буквально абстракция куска памяти, что может быть примитивнее

    @tianned@tianned18 күн бұрын
    • Переменные в языке не имеют какого либо оверхеда. Тут скорее всего автор хотел подвести все под абстракцию, которая может навредить перфомансу

      @user-rx7uq6mk1d@user-rx7uq6mk1d17 күн бұрын
  • Здарова Тиллир)

    @Zayac316@Zayac31620 күн бұрын
    • Осколки старой RSDN-гвардии находят друг друга на ютубе? 😅

      @linkernick5379@linkernick537916 күн бұрын
    • @@linkernick5379 все гораздо веселее=)

      @Zayac316@Zayac31616 күн бұрын
  • Такое ощущение, что С++ создан, чтобы бороться с самим собой. Если на других языках пишут программы и рассказывают о том как решают задачи, то про С++ только и речь, о том как бороться с его косяками.

    @_sergeevich5827@_sergeevich582720 күн бұрын
    • Главным косяком С++ уже давно стал С++ 😊

      @user-qt5hy3vn5p@user-qt5hy3vn5p20 күн бұрын
    • Задачи разные. Нужно быть сильно более упоротым чтобы в контексте Java доехать до оверхедов виртуализации и сделать с этим что-то осмысленное. Вы смотрите задротский видос про оверхеды абстракций и жалуетесь что не рассказывают как мы запустили проект с котиками в вебе

      @isadora-6th@isadora-6th19 күн бұрын
    • С++ это вещь в себе, существует только ради себя и для себя

      @alexmid@alexmid19 күн бұрын
    • В этом докладе ни слова о борьбе с косяками C++. У C++тоже возможно есть косяки, как и у любого другого языка. Но доклад не об этом. Вы даже не разобрались в теме и пришли лить грязь на то, в чëм не разбираетесь.

      @ufabiz@ufabiz18 күн бұрын
    • @@ufabiz чего такой агрессивный ? Никто тут грязь не льёт, успокойся.

      @_sergeevich5827@_sergeevich582718 күн бұрын
  • 35:14 какие 2,5 раза? Из чего вытекает?

    @alexandrgonzales6503@alexandrgonzales650317 күн бұрын
  • касательно исключений я бы сделал следующий ход, я бы обложил его условным препроцессором и запускал его и валидация происходила бы только в режиме дебага, в релизном режиме можно в принципе не использовать обработчик исключений

    @user-tp1qn2wt6t@user-tp1qn2wt6t20 күн бұрын
    • А как возвращать ошибку через 10 функций от того, что лог файлик не записать, диск read+only? abort? Зачем делать ручное прокидывание по каналу return (std::expected), если используете исключения? Они же про делать меньше работы, а перформанс хит у вас на случаи когда прям произошла фигня и работать дальше не сменив курс не выйдет

      @isadora-6th@isadora-6th19 күн бұрын
    • @@isadora-6th ну наверное, идея в том, что будет программу можно собрать для отладочного режим и для рабочего

      @user-tp1qn2wt6t@user-tp1qn2wt6t19 күн бұрын
    • @@user-tp1qn2wt6t Так теперь поведение в дебаг сборке и релизе фундаментально отличается механикой обработки ошибок. У вас буквально с expected все вызовы функций будут обернуты лапшой по передаче еррор-кодов вверх, зачем тут тогда экспешены. А если просто "убрать экспешены" в релиз билде, без перепила всего проекта, то получим std::terminate на безобидное "нет места на диске". Как не использовать обработчик исключений если исключительные ситуации это не сегфолты, а нормальное поведение?

      @isadora-6th@isadora-6th19 күн бұрын
    • @@user-tp1qn2wt6t И попросим окружающую вселенную, чтобы в рабочем режиме исключительных ситуаций не возникало.

      @vr360_progress4@vr360_progress419 күн бұрын
    • @@user-tp1qn2wt6t И в рабочем режиме либо не проверять ошибки, либо тупо аборт по любому исключению. Идея не очень, по-моему.

      @vr360_progress4@vr360_progress416 күн бұрын
  • Каждый раз когда я смотрю подобные видео, то приисполняюсь чувством возвышенного. Кресты это самый человеческий язык, где сосредоточена амбивалентность нашей жизни. Любовь и ненависть. Печаль и радость. Скажи свой язык и я скажу кто ты. Ява - ты почему то решил, что всё в воли человека. Си - ты монах и делаешь свой Сизов труд. Питон - ты предаешься грехопадению и безудержному наслаждению. ЖС - плывёшь по течению. Хаскель - ты грязный джанки плюющий на всю традицию и наследие. Но в нашей христианской традиции только кресты и ничего больше.

    @MsMrlightning@MsMrlightning18 күн бұрын
    • 5 лет назад я нашёл время изучить и освоить Rust и с тех пор вообще перестал видеть смысл брать C++ для чего бы то ни было (хотя C есть смысл брать в ряде сценариев). Да, Rust очень непрост, но понятно, ради чего все эти сложности - чтобы получить безопасные и легковесные модули, а проект RustBelt позволяет получать гарантии даже. В случае же C++ мы в конечном итоге получаем "амбивалентность" 😂

      @linkernick5379@linkernick537917 күн бұрын
  • Имхо реальные программы на си ПЛАС ПЛАС никогда не бывают быстрее программ на c# (написанные за одинаковое время одинаковым количеством людей). Быстрее только бенчмарки с функциями по 10 строк кода (а тут по 1 строчные приводят - фейспалм). Главный принцип разработки ПО это управление сложностью. Где упрощение и где си плас плас...

    @mezmay12@mezmay123 күн бұрын
  • вот что я скажу ребята: не для того придумывали высокоуровневые языки, чтобы на них было сложнее писать чем на машинных кодах. те кто довел с++ до всего этого по-моему окончательно оторванные от этого мира люди, они делают этот язык ради самого языка, их вообще не интересует как им пользоваться в реальной жизни. Очень хочется применить куда более выразительные глаголы

    @alexmid@alexmid20 күн бұрын
    • C++, выиграл гонку вооружений через скорость работы. Если вы действительно хотите высокоуровневый код - пишите на JS, там полиморфизм и типы на рантайме. Перформанс это сложно, не выходит у человечества сложные вещи выражать просто.

      @isadora-6th@isadora-6th19 күн бұрын
    • Как сладостно лектор произносит "си плас плас", мммм, как он доволен собой, как он играет, как любуется собой. А вы про простоту. У них там три игрока бичмаркают, а вы...

      @user-hh2qp6ez4d@user-hh2qp6ez4d19 күн бұрын
    • Тут борятся за каждую наносекунду. А непроизводительный код написать легко и на чём угодно. Да и ничего сложного в презентации нет.

      @phusicus_404@phusicus_40419 күн бұрын
    • Как и в любой другой области деятельности - когда разберешься, то ничего сложного нет, особенно когда разжуют и в рот положат, но не ошибись ли вы языком, если наносекунды важны? Вопрос, однако...

      @alexmid@alexmid19 күн бұрын
    • @@alexmid Если вы про С, то плюсы могут быть быстрее него, и С топорный язык, в котором очень сложно сделать абстракции. А в этой лекции и обсуждаются абстракции без потери производительности. Ну и лекции по углубленному С++ есть в открытом доступе.

      @phusicus_404@phusicus_40419 күн бұрын
  • Всё хорошо, но лекция для людей, которые хорошо разбираются в слэнге: "итерсвап", "из интов" - попахивает каким-то лютым снобизмом. Похоже на гайды по варкрафту от школьников "пуржим шилд, рапчей накладываем блиды и сало отдаём в нову"...

    @yohohowowowo9471@yohohowowowo94713 күн бұрын
KZhead