Errores comunes en la asignación de memoria dinámica de C ++

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;
}

Liberar memoria varias veces
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;
}

La memoria de liberación es una dirección que no es de aplicación
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;
}

Continuar usando después de liberar un bloque de memoria
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;
}

Fuera de los límites

Supongo que te gusta

Origin blog.csdn.net/jjswift/article/details/112733265
Recomendado
Clasificación