IO ()
getLine :: IO String
printStrLn <$> getLine :: IO ( IO () )
Не исполнит сразу все сайд-эффекты, так как "триггером" для того, чтобы редуцирование пошло дальше - является аппликация вида :
IO ()
Но никак не:
IO ( IO () )
Это тоже своего рода ленивость? Или как понять, что эффекты исполняются в последовательности только при "plain" unit-е для IO?
Что почему ты считаешь, что должно быть два IO? Вначале исполнится эфект первого(getLine), потом второго(printStrLn), так как нужно получить значение
Я пытаюсь ответить себе на вопрос в книге: Почему результат fmap в виде IO ( IO () ) не исполняет в последовательности IO (), который был вложен в IO ( ... ) Я понимаю, что можно просто: getLine >>= putStrLn Где применится join, чтобы избавиться от записи: IO ( IO () )
Какой IO (IO () ) ?? Откуда? fmap это функция работающая для одно контейнера, она не делает новый
Вопрос не поняли. datatype IO обязательно должен быть в виде IO (), чтобы произошло исполнение сайд-эффекта? И почему?
исполняется только один IO — main он всегда имеет тип IO ()
у тебя просто эффект завёрнут в эффект, как значение Если мы сделаем foo = printStrLn <$> getLine main = x <- foo putStrLn "Hi" То у нас попросит ввода, а потом напишет HI
Из этого следует, что IO ( IO () ) просто не совпадает по типу с main :: IO () И ничего не выполнит?
не совсем рэббит сверху нормально объяснил
Если ты без x <- напишешь, то просто будет _ <-
Обсуждают сегодня