c - 出现在 C 数组末尾的随机字符

标签 c arrays data-structures initialization valgrind

我有代码:

else if ((strtolnum=(strtol(&oldline[b+1],NULL,10)))>0)
        {
            char* excl = malloc(3*sizeof(char));
            excl[0]=oldline[b];
            excl[1]=oldline[b+1];
            for (int j = 0; j<strtolnum; j++)
            {
                llist=llist->nextcmd;
            }
            struct token *p1;
            struct token *save1 = llist->cmmd;
            char *arra1 = malloc(sizeof(char));
            memset(arra1, '\0', 1);
            for (p1 = llist->cmmd;  p1 != NULL;  p1 = p1->next) {
                arra = realloc(arra1, strlen(arra1)+strlen(p1->text)+2);
                strcat(arra, p1->text);
                if (p1->next!=NULL)
                {
                    strcat(arra1, " ");
                }//   printing token and type
            }
            printf("%s excl\n", excl); //Line 137
            oldline=strreplace(oldline,excl,arra1); //Line 138
            llist->cmmd=save1;
            for (int j = 0; j<(f-strtolnum); j++)
            {
                llist=llist->nextcmd;
            }
            *status=1;
            size_t a = sizeof(excl);
            memset(excl,'\0', a);
        }

代码应该完成的是获取前面有感叹号部分(例如 !3)的行的第一个整数,并将其放入 excl 中(然后执行其他工作正常的事情)。

但是,当我多次运行循环时,我发现 excl 的末尾经常有一个随机字符,例如当我尝试 printf 时它显示为“!3e”。 Valgrind 显示以下错误:

==24878== Conditional jump or move depends on uninitialised value(s)
==24878==    at 0x4E7AB5B: vfprintf (in /usr/lib64/libc-2.17.so)
==24878==    by 0x4E83CD8: printf (in /usr/lib64/libc-2.17.so)
==24878==    by 0x40130F: hExpand (Lex1.c:137)
==24878==    by 0x400B6B: main (mainLex.c:27)
==24878== 
==24878== Conditional jump or move depends on uninitialised value(s)
==24878==    at 0x4C2B308: strlen (in /usr/lib64/valgrind/vgpreload_memcheck-amd64-linux.so)
==24878==    by 0x4020D7: strreplace (Lex1.c:562)
==24878==    by 0x40132C: hExpand (Lex1.c:138)

显然,excl 在循环一次后就被单元化了。怎么了?

补充说明,cmmd是token类型的数据结构,llist是包含token的全局静态数据结构。

最佳答案

你还没有用 null 终止 excl 字符串; malloc() 返回随机垃圾。您可能会考虑添加:

excl[2] = '\0';

您还可以通过以下方式越界:

size_t a = sizeof(excl);
memset(excl,'\0', a);

您将 4 或 8(32 位或 64 位)分配给 a,然后写入那么多字节,但您只为 excl 分配了 3 个字节>.

关于c - 出现在 C 数组末尾的随机字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26500670/

相关文章:

Linux 上的 C-RPC(冒泡排序)

c - 从 Go 初始化灵活数组 C 结构成员

c - 字符串值数组中缺少条目

google-app-engine - 为什么 Google 应用引擎将 URL、电话号码等识别为特殊数据类型?

matlab - 如何在 Matlab 中向量化结构上的操作?

c - 来自 ANSI C K&R 的位运算符

c - ioctl 给出无效参数

php - 如何从 php 数组生成唯一的字符串

python - 去除 Python 中数组列表中的空数组和零数组

java - 在java中创建树数据结构?