Foro de elhacker.net

Programación => Programación C/C++ => Mensaje iniciado por: Gallu en 17 Julio 2010, 12:47 pm



Título: Fallo en segmentación inexplicable (al menos para mi)
Publicado por: Gallu en 17 Julio 2010, 12:47 pm
Hola a todos , ejecutando el siguiente programa me da un fallo en segmentación , alguien me podria decia  a que se debe ? gracias de antemano
Código
  1.  
  2.  
  3. #include <stdio.h>
  4. #include <string.h>
  5. #include <stdlib.h>
  6.  
  7. typedef struct {
  8. char *nombre;
  9. char *direccion;
  10. int edad;
  11. char *dni;
  12. }type_persona;
  13.  
  14. crear_cliente(type_persona *cliente){
  15.    char aux[50];
  16.    int aux2;
  17.  
  18.        printf("%s", "\nCreando cliente......\n");
  19.        printf("\nNombre del cliente :");
  20.        fgets(aux,50,stdin);
  21.        cliente->nombre = (char*) malloc(strlen(aux) * sizeof(char));
  22.        strcpy(cliente->nombre , aux);
  23.        memset(aux,' ',50);
  24.  
  25.        printf("\nDirección del Cliente:");
  26.        fgets(aux,50,stdin);
  27.        cliente->direccion = (char*) malloc(strlen(aux)*sizeof(char*));
  28.        strcpy(cliente->direccion , aux);
  29.        memset(aux,' ',50);
  30.  
  31.        printf("\nDNI del Cliente:");
  32.        fgets(aux,50,stdin);
  33.        cliente->dni =(char*) malloc(strlen(aux)*sizeof(char*));
  34.        strcpy(cliente->dni , aux);
  35.  
  36.        printf("\nEdad del Cliente:");
  37.        scanf("%d", &(cliente->edad));
  38.        printf("\nsu edad es %d", cliente->edad);
  39.  
  40.        printf("\n Cliente creado !!!!");
  41.  
  42. }
  43.  
  44. int main(){
  45.    type_persona *cliente;
  46.  
  47.    crear_cliente(cliente);
  48.  
  49.    printf("\n%s %s %s", cliente->dni , cliente->nombre , cliente->direccion );
  50.  
  51.    return 0;
  52.  
  53. }
  54.  


Título: Re: Fallo en segmentación inexplicable (al menos para mi)
Publicado por: Og. en 17 Julio 2010, 15:31 pm
Código
  1. crear_cliente(type_persona *cliente)
no tiene tipo de retorno.

deberia ser:
Código
  1. void crear_cliente(type_persona *cliente)

y al compilar en gcc no me da ningún Fallo de segmentación. Que compilador usas?


Título: Re: Fallo en segmentación inexplicable (al menos para mi)
Publicado por: cbug en 17 Julio 2010, 15:33 pm
El fallo de segmentación luego de la muestra se debe a que no reservas el espacio en memoria para el puntero a la estructura, prueba añadiendo:


Código
  1.    cliente = (type_persona*)(malloc(sizeof(type_persona)));


Título: Re: Fallo en segmentación inexplicable (al menos para mi)
Publicado por: Gallu en 17 Julio 2010, 21:10 pm
Gracias por vuestras respuestas ...

Código
  1. crear_cliente(type_persona *cliente)
no tiene tipo de retorno.

deberia ser:
Código
  1. void crear_cliente(type_persona *cliente)

y al compilar en gcc no me da ningún Fallo de segmentación. Que compilador usas?

uso gcc y el error era al ejecutar, no al compilar , el prototipo del método
crear cliente está en un .h , al postear el código olvide ponerlo


El fallo de segmentación luego de la muestra se debe a que no reservas el espacio en memoria para el puntero a la estructura, prueba añadiendo:


Código
  1.    cliente = (type_persona*)(malloc(sizeof(type_persona)));


si, era esto lo que estaba fallando , gracias



Título: Re: Fallo en segmentación inexplicable (al menos para mi)
Publicado por: cbug en 17 Julio 2010, 21:38 pm
De nada  :D


Título: Re: Fallo en segmentación inexplicable (al menos para mi)
Publicado por: nicolas_cof en 18 Julio 2010, 00:21 am
Didacso, algunos consejos...

> Utiliza strncpy() (http://c.conclase.com/librerias/?ansifun=strncpy) en vez de strcpy()

https://foro.elhacker.net/programacion_cc/lo_que_no_hay_que_hacer_en_cc_nivel_basico-t277729.0.html

> Nunca haces uso de la variable int aux2;

> Tanto Didacso como cbug, no hace falta castear malloc() ya que esta devuelve un void*

> En dni y direccion es sizeof( char ); no sizeof( char* );

> Te falta asignar espacio para el caracter finalizador de cadena '\0'

Código:
cliente->dni = malloc( (strlen( aux ) + 1) * sizeof( char ) );

> Acuerdate de liberar la memoria con free() para no dejar memory leaks

Salu10.