Ir ao conteúdo
  • Cadastre-se

Problema- alocação dinâmica de listas


Luã Faria

Posts recomendados

Eu estou com um problema de perder os dados utilizando ponteiro duplo para alocação dinâmica de listas. Quando eu uso free e NULL em uma variavel temp eu perco todos os dados alocados....


#include<stdio.h>
#include<stdlib.h>
typedef struct{
	int x,y;
}ponto;
typedef struct a{
	ponto p1,p2;
	struct a *prox;
}no;
no *aloca_no(){
	no *a;
	if(!(a=malloc(sizeof(no))))
		exit(1);
	return a;
}
void lerDados(no **dadosEntrada, char *local){
	FILE *arquivo;
	no *vsf;
	if(!(arquivo = fopen(local,"r"))) 	
		exit(1);
	else{
		printf("Foi\n");
		while(!(feof(arquivo))){ 
			if(*dadosEntrada == NULL)
				(*dadosEntrada) = aloca_no();
			else{
				vsf = aloca_no();
				vsf->prox = *dadosEntrada;
				*dadosEntrada = vsf;
				free(vsf);//Aqui esta o problema, sem essa instrução e a de baixo funciona
				vsf = NULL;		
			}
			fscanf(arquivo,"%d %d %d %d\n", &((*dadosEntrada)->p1.x), &((*dadosEntrada)->p1.y), &((*dadosEntrada)->p2.x), &((*dadosEntrada)->p2.y));
			printf("%d %d\n", (*dadosEntrada)->p1.x, (*dadosEntrada)->p1.y);
		}
	}
}
void main(){
	no *teste;
	char local[50]="/home/lua/Workspace/Algoritmos2/dados.txt";	
	lerDados(&teste, local);
	for(int i = 0; i<29; i++)
	{
		printf("%d %d \n",teste->p1.x, teste->p1.y);
		teste =teste->prox;
	}
}

Não sei porque n fica colorido esse codigo maldito

Link para o comentário
Compartilhar em outros sites

Visitante
Este tópico está impedido de receber novas respostas.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...