ChatGPT для программиста
Dec. 27th, 2022 06:37 pm![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
Я понял, что бы я хотел вот от этого ChatGPT. Это, конечно, нифига не интеллект. Но это — хрень, которая работает без ошибок и не задалбывается от рутины.
В моём любимом OpenSSL типичная функция на 10 строчек содержательной работы содержит 10 строчек инициализации, 40 строчек проверок того, что инициализация и содержательная работа удались (функция вернула нужное значение) и ругань по этому поводу, и ещё 10 строк очистка тех ресурсов, которые я насоздавал. И форматирование, которое, впрочем, можно поручить редактору, осталось понять, как именно.
А хочу я написать эти 10 содержательных строчек, сказать "а теперь вставь все проверки и очистку как в соседних функциях" и получить на выходе код, обвешанный некоторой обвязкой. Можно ещё проверить на типовые ошибки типа buffer overflow. В общем, даже на первый взгляд производительность содержательно растёт в разы.
В моём любимом OpenSSL типичная функция на 10 строчек содержательной работы содержит 10 строчек инициализации, 40 строчек проверок того, что инициализация и содержательная работа удались (функция вернула нужное значение) и ругань по этому поводу, и ещё 10 строк очистка тех ресурсов, которые я насоздавал. И форматирование, которое, впрочем, можно поручить редактору, осталось понять, как именно.
А хочу я написать эти 10 содержательных строчек, сказать "а теперь вставь все проверки и очистку как в соседних функциях" и получить на выходе код, обвешанный некоторой обвязкой. Можно ещё проверить на типовые ошибки типа buffer overflow. В общем, даже на первый взгляд производительность содержательно растёт в разы.
no subject
Date: 2022-12-27 06:02 pm (UTC)В некоторых языках, отличных от C, проверки, что инициализация и содержательное удались, и ругань по этому поводу, прячутся в автопроброс исключений. А очистка ресурсов — в детерминированно вызываемые деструкторы, или в менеджеры контекстов, или в финализаторы. И, казалось бы, никакой ChatGPT не нужен. Однако, тем не менее, люди находят всё новые грабли, на которые наступать.
no subject
Date: 2022-12-27 06:07 pm (UTC)no subject
Date: 2022-12-27 06:44 pm (UTC)no subject
Date: 2022-12-27 06:33 pm (UTC)Насчёт того, что ChatGPT работает без ошибок - ну это явно преувеличение. И дебажить его код - то ещё удовольствие. Причём, ошибки вполне человеческие: например, он запутался с приоритетами тернарного оператора и присваивания.
Возможно, из ChatGPT можно сделать хороший линтер. Но, опять же, он будет работать "скорее всего", и поломка им кода не будет означать ошибку в ChatGPT, в отличие от используемых сейчас линтеров и оптимизаторов, которые должны работать математически строго.
no subject
Date: 2022-12-27 07:43 pm (UTC)Я бы лучше смотрел в сторону лучших языков которые это дело автоматизируют.
no subject
Date: 2022-12-27 08:32 pm (UTC)no subject
Date: 2022-12-28 06:07 am (UTC)Вот пусть он приходит в код-ревью и комментирует: «а вот тут не забыли единицу отнять?» И дальше разработчик комментирует, почему именно в этом месте отнимание единицы не нужно, резолвит тред и мёржит код.
no subject
Date: 2022-12-27 06:40 pm (UTC)- Иваныч, приходи к нам обратно, нам программист нужен.
- Так у вас же обезьяна с GPT-3 есть.
- Обезьяна с GPT-3 уже тимлидом стала, нам опять программист нужен.
no subject
Date: 2022-12-27 06:45 pm (UTC)no subject
Date: 2022-12-27 07:02 pm (UTC)no subject
Date: 2022-12-27 07:15 pm (UTC)no subject
Date: 2022-12-27 07:44 pm (UTC)no subject
Date: 2022-12-28 06:08 am (UTC)Ладно бы чепухи, он ещё и лицензии нарушает.
no subject
Date: 2022-12-27 07:45 pm (UTC)no subject
Date: 2022-12-27 07:56 pm (UTC)Мое такое ощущение, что тебе нужен dsl. Нет?
no subject
Date: 2022-12-27 08:09 pm (UTC)no subject
Date: 2022-12-28 06:11 am (UTC)[[nodiscard]]
же? Можно под макросом, чтоб проверять только в одной специальной сборке, а обычным клиентам не мешать жить.no subject
Date: 2022-12-28 01:43 pm (UTC)no subject
Date: 2022-12-28 02:26 pm (UTC)Тогда
[[nodiscard]]
без дополнительных уточнений. Компилятор откажется компилировать вызов, чей результат немедленно отбрасывается. А если он сохраняется в неиспользуемую переменную, то дальше включаем ворнинг про неиспользуемые переменные и промотируем его до ошибки.Это, впрочем, автоматизация проверки того, что человек не забыл написать проверку результатов, а не автоматизация написания проверки результатов как таковой.
no subject
Date: 2022-12-27 08:16 pm (UTC)Или оно не настолько единообразно, чтобы позволить такой подход?
Или мы боремся за такты, и нам всегда надо внутреннюю функцию инлайнить, чтобы сэкономить вызов, а компилятор такое колдунство не умеет?
no subject
Date: 2022-12-27 08:31 pm (UTC)- проверить аргументы
- породить из них какие-то локальные объекты, при неудаче выругаться (часто контекст-специфично), перейти по goto в конец, где за собой убирают
- сделать содержательные шаги, тоже проверив, что каждый из них удался, при ошибке перейти к освобождению
- присвоить содержательный результат возвращаемой переменной
- освободить вот это вот всё (3-4-много объектов)
- вернуть результат
Единообразие кончается на этом уровне, каждая функция странная по-своему.
no subject
Date: 2022-12-27 08:35 pm (UTC)no subject
Date: 2022-12-27 11:49 pm (UTC)- проверить аргументы
То есть у нас набор аргументов задает некоторый тип, к которому положена функция-валидатор. Я не готов утверждать, что это изоморфно классу с конструктором, но до отвращения похоже.
- породить из них какие-то локальные объекты, при неудаче выругаться (часто контекст-специфично), перейти по goto в конец, где за собой убирают
Задержанная инициализация, которая, если мы не кидаемся исключениями, возвращает код ошибки, который мы можем скормить специфичной для типа функции, чтобы получить смысл. Ах, да, и убрать за собой. Хм... пара методов и деструктор.
- сделать содержательные шаги, тоже проверив, что каждый из них удался, при ошибке перейти к освобождению
Если мы продолжаем оставаться в ООП-парадигме, то это, по сути, перегруженный для каждого подкласса абстрактный метод.
- присвоить содержательный результат возвращаемой переменной
Ну это не проблема в какой угодно парадигме
- освободить вот это вот всё (3-4-много объектов)
Деструктор!
- вернуть результат
Не проблема.
Итого это все выглядит подозрительно похоже на галерею типов с однообразным интерфейсом. Я тут не готов махать руками за изоморфность, но варианты реализации "в общем виде" могут сводиться к вариантам того, как сходная задача решена под капотом в плюсах, джаве или, к примеру, голанге.
no subject
Date: 2022-12-28 01:45 pm (UTC)no subject
Date: 2022-12-28 02:13 pm (UTC)no subject
Date: 2022-12-29 10:13 am (UTC)no subject
Date: 2022-12-29 11:56 am (UTC)Очень условно, у тебя сигнатура функции
int some_func(void* args, void* error);
Далее, у тебя есть функция
char* some_func_error_helper(int retcode, void* error);
которая по коду ошибки и дополнительной информации (которая запросто может быть NULL в большинстве случаев) выдает тебе удобочитаемое сообщение.
Другое дело в том, что достаточно далеко по этой дороге ты уже начинаешь руками реализовывать либо голанг-возврат (у меня так было в одной кодобазе), либо легковесные исключения.
no subject
Date: 2022-12-28 01:59 am (UTC)А ход и логику выполнения надо либо контролировать, либо не контролировать, убирая под диван. На чём же и как сконцентрировать своё внимание в тексте – это вопрос может быть и к визуализатору текста.
no subject
Date: 2022-12-28 01:06 pm (UTC)no subject
Date: 2022-12-28 02:29 pm (UTC)О, а ещё за форматирование. Сейчас в C++-мире, за неимением лучшего, форматирование кода поручают clang-format’у. Который ужасен настолько, что считает допустимым мешать табы с пробелами. Нейронка, которая будет смотреть на весь уже имеемый стиль кода проекта, и форматировать последний дифф под него —
:take_my_money:
(на самом деле нет, take my employer’s money).no subject
Date: 2022-12-29 10:05 am (UTC)no subject
Date: 2022-12-29 11:26 am (UTC)editorconfig, что ли? Ну это не то. Это минимальный набор: табы vs пробелы, сколько позиций в одном табе, кодировки, стиль концов строк. А кодстайл подразумевает ещё и ответы на вопросы: где разбивать длинные строки, где пробелы вокруг пунктуации, как индентить продолжение строки, можно ли или нет короткое тело метода или лямбду писать в одну строчку, вот это всё. И это всё очень хреново формализуется, а когда оно формализовано и энфорсится гит-хуками, то начинает оскорблять чувство прекрасного.