Ленивость+побочные эффекты
Mar. 28th, 2010 05:20 pmВторой день созерацию результаты "отсутствия монады IO, нечистоты и опциональной ленивости" в F#. Читаю из базы данных структуру данных ленивым образом - какой-то только, прости меня господи, херни не творится при этом. То значение прочитается после закрытия DataReader из которого оно читается, то команда окажется закрытой уже. Хорошо хоть в контексте коннекта и транзакции я уверен - вся работа происходит внутри их.
Предполагаю, что при определенном уровне сложности проще все будет сделать неленивым и всасывать в память, чем разбираться в стеках вызовов в которых половина фреймов - из автосгенеренных классах с малопонятными именами. Отладчиком по большей части этого всего пройтись невозможно - он не работает.
Предполагаю, что при определенном уровне сложности проще все будет сделать неленивым и всасывать в память, чем разбираться в стеках вызовов в которых половина фреймов - из автосгенеренных классах с малопонятными именами. Отладчиком по большей части этого всего пройтись невозможно - он не работает.
no subject
Date: 2010-03-28 05:30 pm (UTC)no subject
Date: 2010-03-28 06:16 pm (UTC)Что альтернатива - сесть и 99% времени заниматься работой уровня "студент второго курса на полставки". Т.е., неделями писать "таблица -> поля -> CRUD-запросы -> гуй редактора -> печатная форма"хN, не приходя в сознание.
Я лучше это же самое время подолблюсь с кодогенератором, который сильно отличается от всего того, что мы обычно делаем, а потом сгенерю все на нем. И потом каждый раз когда будут парить мозг всякой ересью - буду опять генерить.
no subject
Date: 2010-03-28 05:37 pm (UTC)no subject
Date: 2010-03-28 05:46 pm (UTC)Функция там будет, конечно, зело ужасная, т.к. там внутри чтения еще несколько вложенных чтений, но скорее всего это должно помочь.
no subject
Date: 2010-03-28 06:30 pm (UTC)Continue of result_t | Stop?).Ещё есть with-идиома, где открытие и освобождение ресурса явные (освобождение -- опционально), и в читающую функцию передаётся уже открытый "дескриптор" (то есть, он не выбросится просто так, при сборке мусора). Это полезно ещё корректной обработкой исключений, если они вдруг используются в фа-диезе.
Но самое грамотное тут -- коиндуктивные данные (в окамле это модуль Stream и stream parsers). Есть и удобства а-ля "ленивые списки" (те самые stream parsers), есть и теория под ними, есть и гарантии о количестве используемых ресурсов (в отличие от ленивых списков), хороши и комбинаторы поверх них.
И соглашусь -- ленивый подход тут плох.
no subject
Date: 2010-03-28 07:05 pm (UTC)no subject
Date: 2010-03-28 08:00 pm (UTC)no subject
Date: 2010-03-29 04:20 pm (UTC)no subject
Date: 2010-03-29 06:18 pm (UTC)no subject
Date: 2010-03-29 08:39 pm (UTC)no subject
Date: 2010-03-30 05:53 am (UTC)Всё, теперь ты - наш :))))
no subject
Date: 2010-03-28 08:04 pm (UTC)no subject
Date: 2010-03-28 08:35 pm (UTC)Прям щаз пытаюсь понять, как сделан Takusen и насколько это практично: http://okmij.org/ftp/Haskell/fold-stream.lhs
если кто пойдёт по порочному пути
Date: 2010-03-30 05:51 am (UTC)Я начал с предыдущей ссылки, и это было неправильно.
Re: если кто пойдёт по порочному пути
Date: 2010-03-30 06:32 am (UTC)no subject
Date: 2010-03-28 10:16 pm (UTC)