1

我试图重构/修复一个函数,我是否正确地进行了截断?如果不是,这一般应该怎么做?特别想知道潜在的泄漏。

void process_entry(GMenuTreeEntry *entry)
{
    char *name = g_strdup (gmenu_tree_entry_get_name(entry));
    char *exec = g_strdup (gmenu_tree_entry_get_exec(entry));
    int i;

    for (i = 0; i < strlen(exec) - 1; i++) {
        if (exec[i] == '%')
        {
            switch (exec[i+1]) {
                case 'f': case 'F':
                case 'u': case 'U':
                case 'd': case 'D':
                case 'n': case 'N':
                case 'i': case 'c': case 'k': case 'v': case 'm':
                    exec[i-1] = '\0';
                    i++;
                    break;
            }
        }
    }

    g_printf("<item label=\"%s\">\n", g_strjoinv("&amp;", g_strsplit(name,"&",0))),
    g_printf("<action name=\"Execute\"><command>%s</command></action>\n", exec),
    g_printf("</item>\n");

    g_free(name);
    g_free(exec);
}

这是一些 GPL 代码,非常感谢您的帮助。总的来说,我对 C 语言还是很陌生,而 glib 我确实是全新的。

4

1 回答 1

1

gchar与 完全相同char,因此您在此处执行的任何操作也适用于常规 C 字符串。

当您在字符串上调用free()org_free()时,它不会计算strlen()以找出要释放的内存量;无论最初在该地址分配多少内存,它都会释放。否则,您永远无法释放未在某处指定其分配内存长度的指针。所以截断字符串是安全的。

于 2013-10-19T03:27:26.827 回答