簡體   English   中英

多次調用函數時出現分段錯誤

[英]Segmentation fault on calling function more then once

再運行一次此功能將導致細分錯誤,我無法弄清原因。 我沒有在尋找其他方法來分割字符串。

SplitX將繼續拆分x個定界符(無論是'|'還是'\\ 0'),並返回x或它可以創建的子字符串數。

我應該注意,經過3年簡單的JavaScript和PHP編寫后,我剛剛重新開始用C語言進行編碼,因此我可能會丟失一些明顯的東西。

int splitX(char **array, char *string, int x) {
    int y;
    int z;
    int index = 0;
    int windex = 0;
    for(y = 0; y < x; y++) {
        z = index;
        while(string[index] != '\0' && string[index] != '|') {
            index++;
        }
        char **tempPtr = realloc(array, (y+1)*sizeof(char *));
        if(tempPtr == NULL) {
            free(array);
            return -3;
        }
        array = tempPtr;
        array[y] = malloc(sizeof(char) * (index - z + 1));
        windex = 0;
        for(; z < index; z++) {
            array[y][windex] = string[z];
            windex++;
        }
        array[y][windex] = '\0';
        if(string[index] == '\0')
            break;
        index++;
    }
    return y+1;
}

int main() {
        char **array;
        int array_len = splitX(array, query, 2);
        printf("%s %s %d\n", array[0], array[1], array_len);
        while(array_len > 0) {
            free(array[array_len-1]);
            array_len--;
        }
        free(array);
        array_len = splitX(array, "1|2\0", 2);
        printf("%s %s %d\n", array[0], array[1], array_len);
        while(array_len > 0) {
            free(array[array_len-1]);
            array_len--;
        }
        free(array);
}
char **array;
int array_len = splitX(array, query, 2);

這使splitX()使用未初始化的array ,從而導致未定義的行為。

此外,C沒有傳遞引用-在編寫時

 array = tempPtr;

在函數內部,在函數外部沒有可見效果。

我沒有在尋找其他方法來分割字符串。

你真的應該 您當前的方法充其量是非慣用的,但是它也存在其他一些錯誤(例如由於某種原因y肯定會返回y + 1等)。

您還需要重新設計輪子:對於字符串和字符搜索,請使用C標准庫中的strstr()strchr()strtok_r() 對於字符串的復制,請使用strdup()而不是手動遍歷該字符串等。

還有什么:

  • 使用size_t代替int ;

  • 通過對輸入字符串使用const char *來保持const正確性。


char **split(const char *s, size_t *sz)
{
    char **r = NULL;
    size_t n = 0, allocsz = 0;
    const char *p = s, *t = p;
    int end = 0;

    do {
        const char *tmp = strchr(p, '|');
        if (tmp == NULL) {
            p = p + strlen(p);
            end = 1;
        } else {
            p = tmp;
        }

        if (++n > allocsz) {
            if (allocsz == 0)
                allocsz = 4;
            else
                allocsz <<= 1;

            char **tmp = realloc(r, sizeof(*r) * allocsz);
            if (!tmp) abort(); // or whatever, handle error
            r = tmp;
        }

        r[n - 1] = malloc(p - t + 1);
        memcpy(r[n - 1], t, p - t);
        r[n - 1][p - t] = 0;

        p++;
        t = p;
    } while (!end);

    *sz = n;
    return r;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM