开发者

Wrong IO actions order using putStr and getLine

开发者 https://www.devze.com 2022-12-24 09:01 出处:网络
I have the following code: main = do putStr \"Test input : \" content <- getLine putStrLn content When I run it (with runhaskell) or compile it (ghc 6.10.4) the result is like this:

I have the following code:

main = do
    putStr "Test input : "
    content <- getLine
    putStrLn content

When I run it (with runhaskell) or compile it (ghc 6.10.4) the result is like this:

asd
Test input : asd

Why is Test input : asd being printed after asd?

In the code sample开发者_如何学Go on http://learnyouahaskell.com/, which uses putStr, the getLine's presented output is different than mine. When I use putStrLn the program works as expected (print, then prompt, and print).

Is it a bug in ghc, or it is the way that it should work?


This is because ghci disables buffering, while a program compiled with ghc has line buffering by default. You can see this by running this:

import System.IO
main = print =<< hGetBuffering stdout

In ghci you see NoBuffering while with runghc you get LineBuffering. Since the newline character doesn't print until after the user input, the prompt doesn't either.

Fix it by adding hFlush stdout after your prompt (or disable buffering with hSetBuffering stdout NoBuffering, but that’s probably bad).

0

精彩评论

暂无评论...
验证码 换一张
取 消