metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-11-14 11:24 pm

На тему споров про хаскель и отладки программ

Посетила странная мысль - если стек вызовов в программе становится слишком глубоким (не считая рекурсий по данным, видимо), это означает, что уровень абстракции, предоставляемый используемым инструментом разработки, не соответствует решаемой задаче.

То есть, например, если я использую какую-то библиотеку - должно быть пофиг, как там она делает внутри себя, это должно быть черным ящиком, в том числе и в стеке вызовов. И если нужно отлаживать библиотеку - это нужно делать отдельно, когда кроме нее в стеке вызовов сверху только Main() сидит. А если мы отлаживаем конечную программу - то вызов библиотеки будет сидеть внизу стека, одной строкой.

[identity profile] smalgin.livejournal.com 2009-11-15 03:33 am (UTC)(link)
Разве это уровень абстракции? Вы просто озвучили правильную и неправильную инкапсуляцию, не?

[identity profile] oldmann.livejournal.com 2009-11-15 06:48 am (UTC)(link)
ребе, какой еще хаскель в шабат ночью?

[identity profile] vp.livejournal.com 2009-11-15 04:46 pm (UTC)(link)
Весьма здравая мысль, кстати. Я в смысле по поводу такого критерия.

[identity profile] udpn.livejournal.com 2009-11-15 06:13 pm (UTC)(link)
Это не странная мысль (, это в тебе пробуждается Сила, юный джедай). Был бы единый репозиторий библиотечного кода со злыми супервизорами и возможность кросс-оптимизации программы и библиотеки.

[identity profile] black-angel-by.livejournal.com 2009-11-16 03:23 pm (UTC)(link)
ребе, вы еще "Теория представлений групп" почитайте :) ваша область выноса мозга :)

[identity profile] kkirsanov.livejournal.com 2009-11-16 08:27 pm (UTC)(link)
А как выглядит отладка хаскелевской программы?

По идее монады+ленивые вычисления должны порождать такую лапшу, что традиционная отладка в принципе будет бессмысленна.

[identity profile] metaclass.livejournal.com 2009-11-16 08:33 pm (UTC)(link)
Да по идее, через unsafePerformIO в лог писать в нужных местах.
Хотя я бы это дело на уровень компилятора засунул, в виде функции, эквивалентной id, но с записью в какой-нибудь внутренний лог, со стеком/графом вызовов.

[identity profile] tonal.myopenid.com (from livejournal.com) 2009-11-17 10:06 am (UTC)(link)
Это называется Debug.Trace (trace, traceShow)
Но таки советую совоить ghci :)