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分配的内存没有释放造成的