我遇到了 IO 没有按顺序执行的问题,即使在 do 构造中也是如此。
在下面的代码中,我只是跟踪剩下的牌,其中牌是字符元组(一个用于花色,一个用于价值),然后不断询问用户已玩过哪些牌。我希望putStr
在每个输入之间执行,而不是像现在这样在最后执行。
module Main where
main = doLoop cards
doLoop xs = do putStr $ show xs
s <- getChar
n <- getChar
doLoop $ remove (s,n) xs
suits = "SCDH"
vals = "A23456789JQK"
cards = [(s,n) | s <- suits, n <- vals]
type Card = (Char,Char)
remove :: Card -> [Card] -> [Card]
remove card xs = filter (/= card) xs