私は私の大学を代表してこの投稿を投稿しています。
彼は、handle_option(MySQL getopt lib)を使用して構成ファイル(/etc/my.cnf)を読み取るときに、疑わしいメモリリークを発見しました。
彼はmallochost_name、usernameの後に以下のソースコードを実行します。
char* host_name;
char* user_name;
struct my_option mysql_confgs[] =
{
{"host", "h", "MySQL Server", (uchar**) & host_name, NULL, NULL, GET_STR,
REQUIRED_ARG, 0,0,0,0,0,0},
{"user", "u", "userID", "h",(uchar**) & user_name, NULL, NULL, GET_STR,
REQUIRED_ARG, 0,0,0,0,0,0}
}
handle_options(&argc, &argv, mysql_configs, aux_config_reader);
彼は、上記の方法がfree(host_name)とfree(user_name)を使用する代わりにError(Segment)を使用していると述べていますか?それで、これがメモリリークを引き起こす可能性のある理由ですか?
ええと..MySQLの基本はゼロなので、問題の説明を100%提供できない可能性があります。それで、これについて自由に質問してください、そして、私は質問に従って問題の説明の詳細を更新します。
私の大学には言語の壁があるので、彼に代わって投稿しています。
Valgrindレポート:
480 bytes in 1 blocks are possibly lost in loss record 26 of 43
at 0x4A068FE: malloc (vg_replace_malloc.c:270)
by 0x33E4E293C1: my_malloc (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x33E4E2C974: alloc_root (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x33E4E2E620: ??? (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x33E4E2F838: my_load_defaults (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x408BF1: MS_MYSQL_init (MS_MYSQL_O.h:109)
by 0x438A39: main_proc (AccLab.c:221)
by 0x437F8A: main (AccLab.c:67)
75,840 bytes in 158 blocks are definitely lost in loss record 41 of 43
at 0x4A068FE: malloc (vg_replace_malloc.c:270)
by 0x33E4E293C1: my_malloc (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x33E4E2C974: alloc_root (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x33E4E2E620: ??? (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x33E4E2F838: my_load_defaults (in /usr/lib64/mysql/libmysqlclient.so.16.0.0)
by 0x408BF1: MS_MYSQL_init (MS_MYSQL_O.h:109)
by 0x438A39: main_proc (AccLab.c:221)
by 0x437F8A: main (AccLab.c:67)
リークの概要:
definitely lost: 75,840 bytes in 158 blocks
indirectly lost: 0 bytes in 0 blocks
possibly lost: 2,304 bytes in 7 blocks
still reachable: 9,675,408 bytes in 2,387 blocks
suppressed: 0 bytes in 0 blocks
Reachable blocks (those to which a pointer was found) are not shown.
To see them, rerun with: --leak-check=full --show-reachable=yes
For counts of detected and suppressed errors, rerun with: -v
ERROR SUMMARY: 8 errors from 8 contexts (suppressed: 4 from 4)