lomeo: (лямбда)
[personal profile] lomeo
Хорошая статья про монад-трансформеры для тех, кто ещё не понимает как с ними работать:
Monad transformers step-by-step

читаю

Date: 2006-12-05 10:46 am (UTC)
From: [identity profile] nealar.livejournal.com
newtype ReaderT r m a = ReaderT { runReaderT :: r -> m a }
зачем здесь newtype? Чтобы нельзя было руками конструктор ReaderT вызвать?
Чё-то у меня как-то плохо с пониманием newtype. :(

А об instance Monad ((->) r) я чуть моск не сломал

Re: читаю

Date: 2006-12-05 11:27 am (UTC)
From: [identity profile] lomeo.livejournal.com
В смысле, что значит руками вызвать?

newtype оборачивает один тип так, что bottom обёрнутого типа становится bottom для newtype, при оборачивании с помощью data мы будем различать bottom обёрнутого типа и самого. т.е. по идее самого типа нет, это только фича type checker. больше отличий вроде нет.

Поэтому, возможно, это делается для требуемого поведения при исключениях. Возможно, для эффективности (лишнего типа нет). хз.

Здесь на самом деле будет тип r -> m a, т.е. после компиляции runReaderT вызываться не будет - такой функции просто нет.

Это я так думаю, честно говоря. Надо почитать.

Re: читаю

Date: 2006-12-05 11:54 am (UTC)
From: [identity profile] nealar.livejournal.com
Чем от type отличается? С помощью type делается вообще точная копия, а не только bottom.

Re: читаю

Date: 2006-12-05 11:55 am (UTC)
From: [identity profile] lomeo.livejournal.com
тем, что при type - тип тот же, но синоним, а здесь другой (например можешь для этого типа сделать другой инстанс какого нибудь класса).

Re: читаю

Date: 2006-12-05 12:28 pm (UTC)
From: [identity profile] nealar.livejournal.com
Про инстанс я понимаю. А в жизни это зачем нужно? Вот тут у них, типа, конструктор свой, поэтому стандартных инстансов нет, так что, newtype используется не за этим.

newtype

Date: 2006-12-05 01:02 pm (UTC)
From: [identity profile] nealar.livejournal.com
Похоже, для экономии. Памяти под конструкторы или ещё чего-нибудь этакого. Я StateMonad писал через data - и ничего, работала. А у них через newtype.

Re: newtype

Date: 2006-12-05 01:09 pm (UTC)
From: [identity profile] lomeo.livejournal.com
Мы вроде type уже обсуждаем, а не data? Для data всё понятно - эффективность, тип то тот же самый остаётся.

Re: читаю

Date: 2006-12-05 01:07 pm (UTC)
From: [identity profile] lomeo.livejournal.com
Имхо, потому что синоним не позволяет полморфные типа, в данном случае не опишешь синоним для r -> m a.
А newtype позволяет определить тип со своим порядком следования полиморфных типов. И тогда мы можем сказать типа Monad (ReaderT r m) или MonadTrans (ReaderT r). Может быть за этим?

В смысле, описать то type MyReaderT r m a = r -> m a сможешь, а вот instance MonadTrans (MyReaderT r) хрен сделаешь, если я не ошибаюсь.

Re: читаю

Date: 2006-12-05 01:16 pm (UTC)
From: [identity profile] nealar.livejournal.com
Да, GHC не даёт. Я, правда, не понимаю, как он это обосновывает.

Re: читаю

Date: 2006-12-05 02:19 pm (UTC)
From: [identity profile] lomeo.livejournal.com
ХЗ, сейчас на ru_lambda спрошу.

Profile

lomeo: (Default)
Dmitry Antonyuk

April 2024

S M T W T F S
 123456
7891011 1213
14151617181920
21222324252627
282930    

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Jul. 21st, 2025 03:03 am
Powered by Dreamwidth Studios