c/c++ 溢出、越界、泄漏个人小结

1.溢出

c/c++溢出是指进行拷贝操作时接收的buf小于原buf产生的现象,分为栈溢出和内存溢出

1)栈溢出

a.栈溢出是指函数中的局部变量造成的溢出(注:函数中形参和函数中的局部变量存放在栈上)

栈的大小通常是1M-2M,所以栈溢出包含两种情况,一是分配的的大小超过栈的最大值,二是分配的大小没有超过最大值,但是接收的buf比原buf小

例子1:(分配的的大小超过栈的最大值)

void

{

char a[99999999999999999];

}

例子2:(接收的buf比原buf小)

void

{

char a[10] = {0};

strcpy(a, "abjjijjlljiojohihiihiiiiiiiiiiiiiiiiiiiiiiiiii");

}

注意:调试时栈溢出的异常要在函数调用结束后才会检测到,因为栈是在函数结束时才会开始进行出栈操作

如:

int main(int argc, char* argv[])

{

char a[10] = {0};

strcpy(a, "abjjijjlljiojohihiihiiiiiiiiiiiiiiiiiiiiiiiiii");

exit(0);

return 0;

}

这种情况是检测不到栈溢出的,因为函数还没执行完就退出了

void fun()

{

char a[10] = {0};

strcpy(a, "abjjijjlljiojohihiihiiiiiiiiiiiiiiiiiiiiiiiiii");

}

int main(int argc, char* argv[])

{

fun();

exit(0);

return 0;

}

这种情况调用完fun函数就会检测到异常了

b.栈溢出的解决办法

如果是超过栈的大小时,那就直接换成用堆;如果是不超过栈大小但是分配值小的,就增大分配的大小

2)内存溢出

使用malloc和new分配的内存,在拷贝时接收buf小于原buf时造成的现象

解决:增加分配的大小

2.越界

越界通常指的是数组越界,如

char a[9]={0};

cout << a[9] << endl;


3.泄漏

这里泄漏通常是指内存泄漏,是指使用malloc和new分配的内存没有释放造成的


猜你喜欢

转载自blog.csdn.net/wangkui1331/article/details/80475941