sprintf堆栈缓冲区溢出

时间:2019-03-25 09:15:54

标签: c

我正在尝试使用sprintf将字符串存储在char变量中。代码可以编译,但是当我运行它时,我得到了堆栈缓冲区溢出错误。我的编译器向我提供了有关为什么出现错误的信息,但我不能说出实际上是什么错误。

int数字[]是一个长度为6的数组,而matchHighest是一个整数= 0。

我在此函数中调用match6:

int match(int numbers[], int matchHighest){
    int matchArray[] = {0, 0, 0, 0, 0};
    int i = 0;
    char m6[100] = "";
    char *m6p = m6;
    match6(&numbers[i], matchArray, &m6[100]);   

在这里发生错误:

int match6 (int numbers[], int matchArray[5], char *m6){
    int i=0;
    while((numbers[i]==numbers[i+1]) && (i<5)){
        i++;
    }
    if(i == 5){
        matchArray[4] = 6 * numbers[0] + 27;
        sprintf(m6, "Rule match-6(%d) - score %d", numbers[0], matchArray[4]);
        printf("%s\n", m6);
    }
    return matchArray[4];
}

运行时,出现此错误(底部的所有值均正确无误,并与预期的一样):

draft6.c:98运行时错误-堆栈缓冲区溢出

dcc解释:访问超出局部变量的结尾。   确保阵列的大小正确。   确保您的数组索引正确。

执行在第6行第6行的match6(4)-得分51“)处停止:

if(i == 5){
    matchArray[4] = 6 * numbers[0] + 27;
-->     sprintf(m6, "Rule match-6(%d) - score %d", numbers[0], matchArray[4]);
    printf("%s\n", m6);
}

执行停止时的值:

i = 5
m6 = "Rule match-6(4) - score 51"
matchArray[4] = 51
numbers[0] = 4

1 个答案:

答案 0 :(得分:3)

match6(&numbers[i], matchArray, &m6[100]);。您将项目的地址传递到最后分配的项目之外。之后,match6超出范围。不用做奇怪的事情,只需传递数组:

char m6[100] = "";
match6(&numbers[i], matchArray, m6);