为什么我的程序跳过了一个cicle? 13 C

时间:2017-10-10 23:12:14

标签: c loops for-loop valgrind

我试图编写一个将字符串拆分为多个的函数,我知道我有很多未分配的空间,我只是测试了这一点但是valgrind显示了我

 Conditional jump or move depends on uninitialised value(s)  
==25613==    at 0x4C2DB3C: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)  
==25613==    by 0x40090C: split (strutil.c:32)  
==25613==    by 0x400A00: main (strutil.c:45)  
==25613==  Uninitialised value was created by a stack allocation  
==25613==    at 0x400720: split (strutil.c:9)  

一些类似的错误然后sigsem并关闭。我担心的是,当我用gdb运行它时,对于那些应该计算','的圈子,它按预期旋转直到它达到'','然后跳过整个cicle但是i ++并继续前进。为什么这样做?我在gdb上看到了所有参数(str [i],sep)在条件之前的那一刻里面有正确的值。

#include "strutil.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>

char** split(const char* str, char sep){
size_t cant = 2;
size_t i;
for(i = 0; i < strlen(str); i++){//this is line 9
    if(str[i] == sep)
        cant ++;
    i++;
}
size_t corte[cant];
i = 0;
corte[0] = 0;
size_t j = 1;
size_t cant_corte[cant];
for(i = 0; i < strlen(str); i++){
    if(str[i] == sep){
        corte[j] = i + 1;
        cant_corte[j - 1] = corte[j] - corte[j - 1];
        //printf("pasa\n"); 
        j++;
    }
    printf("pasa\n"); 
    i++;
}
char** strv = malloc(sizeof(char*) * cant);
    if (strv == NULL)return NULL;
for(i=0; i < cant; i++){
    strv[i] = malloc(sizeof(char) * cant_corte[i]);
    if (strv[i] == NULL)return NULL;
    strncpy(strv[i], str + corte[i], cant_corte[i-1]);
    strcat(strv[i], "\0");
}
strv[cant + 2] = NULL;
return strv;
}

int main(){
char* eje = "abc,defg";
printf("%s\n", eje);
char r = ',';
char** prueba = split(eje, r);
printf("%s\n", prueba[0]);
getchar();
return 0;
}

1 个答案:

答案 0 :(得分:1)

如果您不希望$ docker exec yourapp_web_1 php artisan config:clear变量继续增加,请确保在for循环中不增加i,而是依赖于for循环来执行“{1}}变量。工作。 (每次条件为真时递增i。)