Has*_*ant 5 io haskell buffering
我遇到的问题是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
Run Code Online (Sandbox Code Playgroud)
absz的答案是正确的,Haskell的缓冲IO是导致你麻烦的原因.这是重写你doLoop有一个你正在寻找的效果的一种方法:
doLoop xs = do putStrLn $ show xs
input <- getLine
let s:n:_ = input
doLoop $ remove (s,n) xs
Run Code Online (Sandbox Code Playgroud)
这两个更改:用于putStrLn附加换行符并刷新输出(这可能是您想要的),并用于一次getLine获取一行(同样可能是您想要的).
| 归档时间: |
|
| 查看次数: |
813 次 |
| 最近记录: |