STATUS_STACK_BUFFER_OVERRUN обнаружен

Я искал эту конкретную ошибку и обнаружил, что основная проблема заключается в неправильном подсчете циклов и в результате чего программа выходит за границы массива.

Однако после того, как я опустил каждый массив до точки, где массив начал терять данные на выходе, он продолжал выдавать ту же ошибку. Я все еще новичок в C / C ++, но любая оценка этого будет принята с благодарностью.

Программа, кажется, работает до самого конца и даже возвращается к основному методу.

#include <stdio.h>void sortAr(char[]);

int main ()
{
char a='y';
char b,i;
char c[20];
int x=0,n=0,z=0;
while (x<=19)
{
c[x]='@';
x++;
}

printf("Enter 20 letters: \n");

while (z<=20) //(The '=' caused my problem, removed and it runs fine.)
{
z++;
x=0;
b='y';
scanf("%c",&i);
while (x<=19)
{
if (c[x]==i)
b='n';
x++;
}

if (b=='y')
{
c[n]=i;
n++;
}
}
printf("\n");
printf("The nonduplicate values are: \n");

sortAr(c);

}
void sortAr(char ar[])
{
char z;
for (int i = 0; i <= 19; i++)
{
for (int j=i+1; j <= 19; ++j)
{
if (ar[i]>ar[j])
{
z =  ar[i];
ar[i] = ar[j];
ar[j] = z;
}
}
}
for (int i = 0; i < 20; i++)
{
if(ar[i]=='@')
continue;
printf("%c ", ar[i]);
}
printf("\n");
}

-3

Решение

Я нашел ошибку в:

while (z<=20)

Причина в том, что массив будет перезаписывать больше символов, чем предполагалось, выполняя больше раз, чем массив проиндексировал в памяти. В результате он записал в память, которая не была ему выделена, и вызвала Stack_Buffer_Overrun.

Trace Z:

Z was initialized to 0.
Array was initialized to 20.

While loop starts with Z as the counter for read-ins.
z=0 array=1 1st run,
z=1 array=2 2nd run,
z=2 array=3 3rd run,
z=3 array=4 4th run,
...
z=20 array=21 21st run. (Array cannot hold 21st character and results in Stack_Buffer_Overrun.)

Решение:

change while(z<=20) -> while(z<20)
1

Другие решения