我正在编写一个网络文件传输应用程序。使用 Lazy ByteString 作为中间体
import qualified Data.ByteString.Lazy as BSL
从本地文件构造 BSL 时,将 BSL 放入 Socket 的句柄中:
BSL.readFile filename >>= BSL.hPut remoteH -- OK
这工作正常。内存使用是恒定的。但要从 Socket 接收数据,则写入本地文件:
BSL.hGet remoteH size >>= BSL.hPut fileH bs -- starts swapping in 1 second
我可以看到内存使用量不断上升,BSL 占用了size字节的内存。更糟糕的是,对于超出我的物理内存大小的大尺寸,操作系统会立即开始交换。
我必须递归地接收 ByteStrings 段。那没问题。
为什么BSL会这样?