1. La memoria solicitada se libera varias veces
int main(void){
int *p = new int[10];
p[0] = 100;
printf("p[0]'s value: %d\n",*p);
delete[] p; //释放内存
delete[] p;
return 0;
}
2. La memoria con pérdida de memoria no se ha liberado después de la aplicación.
int main(void){
int *p = new int[1024];
p[0] = 100;
printf("p[0]'s value: %d\n",*p);
while(1){
*p++;
}
system("pause");
return 0;
}
3. La memoria liberada no es la dirección en el momento de la aplicación.
int main(void){
int *p = new int[1024];
p[0] = 100;
printf("p[0]'s value: %d\n",*p);
for(int i=0; i<10; i++){
*p++;
}
delete[] p; //释放内存
return 0;
}
4. Suelte el puntero nulo.
Puede haber un error, pero no puede escribirlo así sin un error
int main(void){
int *p = NULL;
if(1==0){
p = new int;
}
delete p; //释放内存
return 0;
}
5. Suelte un bloque de memoria, pero continúe haciendo referencia a su contenido
int main(void){
int *p = new int[10];
delete p; //释放内存
p[0] = 100;
printf("p[0]'s value: %d\n",*p);
return 0;
}
6. Acceso transfronterizo
int main(void){
// 越界访问
int *p = new int[10];
memset(p,0,18*sizeof(int));
for(int i=0; i<10; i++){
printf("*p's value: %d\n",*p++);
}
for(int i=0; i<10; i++){
printf("*p's value: %d\n",*p++);
}
return 0;
}