当使用Haskell库连接到Microsoft时,我遇到了内存泄漏问题。
import Database.HDBC
import qualified Database.HDBC.ODBC as ODBC
import Control.Monad
-- | Main application.
main :: IO ()
main = dbTest
dbTest :: IO ()
dbTest = do
let connStr = "DSN=TESTDB;Uid=sa;Pwd=password"
conn <- ODBC.connectODBC connStr
replicateM_ 20000 (loop conn)
disconnect conn
where
loop c = do
result <- getTables c
commit c
putStrLn $ show result运行堆分析器可以使我保持内存使用率,但窗口报告的内存使用量几乎增加到100 me。
http://i.stack.imgur.com/YkUTW.png
在我看来,内存泄漏似乎是在ODBC驱动程序的外部函数接口中,但这是我第一次分析代码,所以我无法确定。有没有人有进一步的洞察力或建议来解决问题?在循环中调用System.Mem.performGC来尝试和清理没有任何效果。
除了使用HDBC之外,还有其他选择吗?如果没有,我可能需要学习F#。
发布于 2015-09-18 09:18:13
问题出现在hdbc-odbc库中。新版本的v2.5可以从Git获得,但是hdbc库也需要修补才能工作。
更多细节可在这个错误报告获得。
https://stackoverflow.com/questions/32408862
复制相似问题