当前位置:Gxlcms > Python > haskell实现多线程服务器实例代码

haskell实现多线程服务器实例代码

时间:2021-07-01 10:21:17 帮助过:22人阅读

代码如下:


module Main where

import Network.Socket
import Control.Concurrent

main :: IO ()
main = do
sock <- socket AF_INET Stream 0
bindSocket sock (SockAddrInet 4242 iNADDR_ANY)
listen sock 10240
mainLoop sock

mainLoop :: Socket -> IO ()
mainLoop sock = do
conn <- accept sock
forkIO $ runConn conn
mainLoop sock

runConn :: (Socket, SockAddr) -> IO ()
runConn (sock, tcp) = do
sms<-recv sock 1024
peeraddr <- getPeerName sock
putStrLn sms
runConn (sock, tcp)

人气教程排行