Тимур Думлер - Контракты для С++

  Рет қаралды 2,145

C++ Russia — Конференция по разработке на Cpp

C++ Russia — Конференция по разработке на Cpp

Күн бұрын

Пікірлер: 15
@niklkelbon3662
@niklkelbon3662 3 ай бұрын
* мы сделали очень расширяемый пропозал по контрактам * но у нас нет ничего кроме рантайм чека, который мы требуем * в будущем что-то добавим (очевидно нет, если требуется рантайм чек, то никаких оптимизаций делать нельзя) И это при том, что вся стандартная библиотека (где в первую очередь должны появится контракты) просто завалена кодом, где нарушение контракта == уб
@КошакРыжый
@КошакРыжый 3 ай бұрын
Все так боятся этого страшного UB. Иногда хочется выписать профилактическую оплеуху очередному докладчику ругающему UB. Почему то все забывают что UB полезен, это отличный способ развязать руки опимизатору. Мы же не хотим при работе с массивом постоянно выполнять проверки выхода за массив, ведь это не бесплатная операция, вот UB и решает эту проблему. В стандарте сейчас есть std::variant который не позволяет бесплатно получить содержимое, std::get и std::get_if выполняют проверку даже если автор кода точно знает что в нем храниться. Вот какой осел до этого додумался? В том же std::optional хватило мозгов сделать небезопасный оператор *.
@asc7uni
@asc7uni 3 ай бұрын
Отличный доклад, спасибо. С языком и терминами всё хорошо и понятно было.
@GenoikVic
@GenoikVic 3 ай бұрын
При просмотре хотелось бы меньше смотреть на слушателей, а больше на экран. Мне лично малоинтересно смотреть на лица других людей.
@КошакРыжый
@КошакРыжый 3 ай бұрын
Проверка в рантайме это чушь, полная чушь. Даже рефлексию делают статической. Как же это плохо, у языка проблема с многословностью уже сейчас в одном объявлении функции можно увидеть template const constexpr static override delete noexcept nodiscard auto, а еще какую нибудь проверку SFINAE и вариадик параметры. Уже доходит до того, что объявление функции может быть в три раза объемнее реализации. Успокойтесь наконец, хватит. Как же я злюсь, в стандарте нет ни графики ни сетей, зато куча концептов да контрактов которые никак не реализуют
@bartolomeykant
@bartolomeykant 3 ай бұрын
А как проверить рантаймовые значения не в рантайме?
@КошакРыжый
@КошакРыжый 3 ай бұрын
@@bartolomeykant Писать обработчик. Дело в том что если требуется проверка значит нужна и корректная обработка, например бросить исключение или вернуть дефолтное значение. Если подразумевается что проверку обязуется выполнить вызывающая сторона, то глупо дублировать такие проверки. Проверки нарушения контрактов обычно выполняют упомянутым в видео assert. Если в коде нужно что-то более серьезное чем assert то на такой случай невозможно придумать стандарт, всегда будут уникальные запросы. Возможно я не правильно понял суть, или автор видело не справился и не донес идею, но то что я увидел сильно разочаровывает. Я был бы рад если бы продвигали в стандарт альтернативу макросу assert или механику позволяющую писать свои ассерты которые работали бы с модулями, но к сожалению в стандарт суют этот мусор, который отвлекает комитет от действительно важных задач. В стандарте есть отличный инструмент static_assert пусть бы развивали его, например сейчас нет простого способа вывести имя типа в лог компилятора. Обычные assert в бывают разбросанные по всему телу функции, это исключительно отладочный инструмент выполняющий роль встроенного юнит-теста, assert использует не только входные и выходные параметры а так же внутреннее состояние функции и даже глобальные данные, т.е. уже имеющийся инструмент горздо мощнее и гибче предлагаемых контрактов.
@bartolomeykant
@bartolomeykant 3 ай бұрын
@@КошакРыжый по сути то что предлагается это asset до вызова функции, после вызова функции и можно еще несколько внутрь функции засунуть. И все это при срабатывании попадет в специальный обработчик, который один на все приложение. Для отладочных целей из этого обработчика можно напечатать стек трейс или дождаться подключения дебагерра. Больше он не зачем не нужен по сути. И этот механизм един во всем коде, какую бы стороннюю библиотеку вы не подключали. Получается вызов функции с контрактом исключает UB, так как нарушение контракта приводит к определенному поведению - крашу приложения. У меня ide мне подсказывает если я обращаюсь к значению optional без проверки, так и тут ide может предупреждать, что для вызова функции нужно сначала убедиться, что контракт соблюдается, а компилятор двойные проверки сможет оптимизировать.
@GrowHobbyRU
@GrowHobbyRU 3 ай бұрын
Правильно нужно больше ключевых слов, а то компилятор пока не понимает нас на родном языке. Ну привели бы хоть статистику какую нибудь на сколько данный функционал востребован и кто им будет пользоваться. А то про мифические 100+ юз кейсы рассказали а кому этот функционал действительно нужен непонятно.
@feelamee
@feelamee 3 ай бұрын
а с чего вы взяли что он кому-то нужен или что авторы делают его для кого-то? кто угодно может написать свой пейпер и прийти с ним в комитет. Вот люди захотели такое в C++ и они это делают. Если хотите что-то еще - вперед. Иначе слишком удобно сидеть на дивание ровно, ничего не предлагая, но критиковать людей которые прикладывают усилия чтобы что-то сделать.
@GrowHobbyRU
@GrowHobbyRU 3 ай бұрын
@@feelamee язык программирования это не помойка куда каждый кому не лень может добавлять свои хотелки. Язык должен быть минимально достаточным, лаконичным , легким в освоение конечно если вы хотите что бы он продолжал жить.
@feelamee
@feelamee 3 ай бұрын
@@GrowHobbyRU я и не говорил что каждый может добавить в C++ что захочет) Я лишь сказал что каждый может попытаться. Согласен с вашим видением языка, но для долгожителей вроде C++ это не работает. Тут всегда есть груз прошлого, который приходится тащить. Но люди стараются делать его проще и лаконичнее. По-моему - получается. И контракты эта одна из полезных фич, которую я бы хотел видеть в C++. Не знаю в таком виде или нет.
@mykola3915
@mykola3915 3 ай бұрын
Переводить технические определения с английского на русский это ужасно. Говорите по нормальному всегда на английском. Когда говорят на русском впечатление будто вы из села или в пту программирование учили
@прокрастинатор-я8в
@прокрастинатор-я8в 3 ай бұрын
запретите русский язык, русскую культуру, россию наконец... маладец
@КимЧенОрк
@КимЧенОрк 3 ай бұрын
Привыкнешь
Антон Полухин - Грязные C++ трюки из userver и Boost
1:00:00
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 4,2 М.
Антон Яковлев - Практика применения C++ в играх и игровых движках
1:00:27
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 4 М.
人是不能做到吗?#火影忍者 #家人  #佐助
00:20
火影忍者一家
Рет қаралды 20 МЛН
Une nouvelle voiture pour Noël 🥹
00:28
Nicocapone
Рет қаралды 9 МЛН
Артур Лаздин - Компиляторы не только для программирования
1:00:49
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 1 М.
Владислав Шпилевой - Аптечка производительности для C/C++ серверов
1:00:11
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 1,8 М.
Алексей Станкевичус - Поиск самой быстрой MPMC-очереди
54:34
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 875
Антон Потапов - Проблема выбора технологий параллелизации (для CPU и общей памяти)
1:00:05
Pure Virtual Cast / Нетрадиционный поиск утечек памяти
1:59:03
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 955
Вадим Винник - Адовая синхронизация. Как ходить на рандеву
59:44
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 1,1 М.
Филипп Белозёров и Владислав Гордиенко - Neat Gamedev Tricks and Beyond
1:03:47
C++ Russia — Конференция по разработке на Cpp
Рет қаралды 1 М.
人是不能做到吗?#火影忍者 #家人  #佐助
00:20
火影忍者一家
Рет қаралды 20 МЛН