mongoc_init() 和 mongoc_cleanup() 可能会使记忆 "still reachable"
mongoc_init() and mongoc_cleanup() may make memory "still reachable"
我有一个 class 可以使用 mongodb-c-驱动程序进行 mongodb 操作。在构造函数中, mongoc_init() 被调用。在解构函数中, mongoc_cleanup() 被调用。然后,valgrind 3.10.1 告诉我一些内存"still reachable"。部分 valgrind 输出如下:
==23222== 1 个块中的 16,384 字节在丢失记录 586 of 586 中仍然可以访问
==23222== 在 0x4C2D199:realloc (vg_replace_malloc.c:692)
==23222== 通过 0x6243894:CRYPTO_realloc(在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== 通过 0x62BE1F1:lh_insert(在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== by 0x62C0828: ??? (在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== by 0x62C0243: ??? (在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== 通过 0x5FCB01D:ERR_load_SSL_strings(在 /lib/x86_64-linux-gnu/libssl.so.1.0.0 中)
==23222== 通过 0x5083623:_mongoc_ssl_init(在 /usr/local/lib/libmongoc-1.0.so.0.0.0)
==23222== 通过 0x5077028:_mongoc_do_init(在 /usr/local/lib/libmongoc-1.0.so.0.0.0)
==23222== 通过 0x529A3FF:pthread_once (pthread_once.S:104)
==23222== 通过 0x400F305:call_init.part.0 (dl-init.c:85)
==23222== 通过 0x400F3DE:call_init (dl-init.c:52)
==23222== 通过 0x400F3DE:_dl_init (dl-init.c:134)
==23222== by 0x40016E9: ??? (在 /lib/x86_64-linux-gnu/ld-2.15.so)
==23222== 泄漏摘要:
==23222== 仍可访问:3,075 个块中的 91,832 字节
当我评论这两个函数 mongoc_init() 和 mongoc_cleanup() 时,valgrind 告诉我所有堆块都已释放。
有什么想法吗?
谢谢。
看来是mongodb-c-driver的问题。
其他人在 mongodb c 驱动程序项目下报告了同样的问题。
https://jira.mongodb.org/browse/CDRIVER-478
我有一个 class 可以使用 mongodb-c-驱动程序进行 mongodb 操作。在构造函数中, mongoc_init() 被调用。在解构函数中, mongoc_cleanup() 被调用。然后,valgrind 3.10.1 告诉我一些内存"still reachable"。部分 valgrind 输出如下:
==23222== 1 个块中的 16,384 字节在丢失记录 586 of 586 中仍然可以访问
==23222== 在 0x4C2D199:realloc (vg_replace_malloc.c:692)
==23222== 通过 0x6243894:CRYPTO_realloc(在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== 通过 0x62BE1F1:lh_insert(在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== by 0x62C0828: ??? (在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== by 0x62C0243: ??? (在 /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 中)
==23222== 通过 0x5FCB01D:ERR_load_SSL_strings(在 /lib/x86_64-linux-gnu/libssl.so.1.0.0 中)
==23222== 通过 0x5083623:_mongoc_ssl_init(在 /usr/local/lib/libmongoc-1.0.so.0.0.0)
==23222== 通过 0x5077028:_mongoc_do_init(在 /usr/local/lib/libmongoc-1.0.so.0.0.0)
==23222== 通过 0x529A3FF:pthread_once (pthread_once.S:104)
==23222== 通过 0x400F305:call_init.part.0 (dl-init.c:85)
==23222== 通过 0x400F3DE:call_init (dl-init.c:52)
==23222== 通过 0x400F3DE:_dl_init (dl-init.c:134)
==23222== by 0x40016E9: ??? (在 /lib/x86_64-linux-gnu/ld-2.15.so)
==23222== 泄漏摘要:
==23222== 仍可访问:3,075 个块中的 91,832 字节
当我评论这两个函数 mongoc_init() 和 mongoc_cleanup() 时,valgrind 告诉我所有堆块都已释放。
有什么想法吗?
谢谢。
看来是mongodb-c-driver的问题。 其他人在 mongodb c 驱动程序项目下报告了同样的问题。 https://jira.mongodb.org/browse/CDRIVER-478