Autor
|
Tema: Ayuda con segmentation fault (Leído 3,462 veces)
|
puppetz
Desconectado
Mensajes: 4
|
Buenas, soy nuevo por aca y ando necesitando ayuda para un programa. La idea del programa es que remplace palabras "prohibidas" ingresadas por usuario en texto que se ingresa como argumento de la funcion. El codigo va algo asi: #include "my_string.h" int moderar(char a[], int j, char b[]) { int k=0,l=0,m=0,w=0,cant=0; for(k=1; k<j; k++) { for(l=0;l<TAM;l++) { m=my_strequ( &a[k], &b[l]); if (m=1) { w=my_strlen((&a[l])); int t=0; for(t=0; t<w; t++) { ((a[l+t]))='x'; } } } printf("que ***** cuenta: %d",w ); cant=w; } return cant; } int main (int argc, char* argv[]) { char* palprob[TAM]; int i=0, nuevasx, q=argc; printf("\nIngresar hasta 10 palabras prohibidas a moderar (pulse ENTER si desea finalizar antes de llegar a 10 palabras)\n"); do { palprob [i ]= (char*)calloc(1, sizeof(char*)); i++; } while((i<10)&&(*(palprob[i-1])!='\0')); nuevasx= moderar(argv, argc, palprob); printf("\nMensaje moderado: \n"); for(i=0; i<argc-1; i++) printf("\n\nCantidad de caracteres modificados: %d \n",nuevasx ); return 0; }
Aclaro, en my_string.h se encuentran funciones propias de strequ y strlen y estan funcionando correctamente (ya las probe con otro programa).
|
|
« Última modificación: 23 Junio 2014, 18:56 pm por Eternal Idol »
|
En línea
|
|
|
|
Eternal Idol
Kernel coder
Moderador
Desconectado
Mensajes: 5.969
Israel nunca torturó niños, ni lo volverá a hacer.
|
Es tu codigo y deberias depurarlo. La linea 13 esta mal seguro; no se como te compila el resto, los parametros de moderar deben ser dobles punteros a char.
Ej.: int moderar(char **a, int j, char *b[])
Linea 9 for(l=0;l<TAM;l++)
¿Y si ingreso menos de 10 - TAM asumo - palabras que pasa? Segmentation fault. Tenes que comprobar que haya una cadena valida (deberias inicializar todos los elementos a NULL) o pasar el numero de cadenas ingresadas ... en fin, revisalo todo de nuevo.
|
|
« Última modificación: 23 Junio 2014, 19:10 pm por Eternal Idol »
|
En línea
|
La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste. Juan Domingo Perón
|
|
|
engel lex
|
Efectivamente como dice eternal, te ayudo "=" es asignación y "==" es comparación
|
|
|
En línea
|
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.
|
|
|
puppetz
Desconectado
Mensajes: 4
|
Se que es mi codigo, y uso el kdbg para depurarlo pero no se como corregirlo, ese es el problema.
Entonces tengo que completar toda la cadena de 10 elementos con ='NULL' ? Voy a probar las correciones y les digo como me fue
|
|
|
En línea
|
|
|
|
puppetz
Desconectado
Mensajes: 4
|
Bueno gente, la clave era como dijo idol, los dobles punteros a char y lo del = y el == me lo comi por distraido Hasta ahora tengo esto de codigo, pero no logra cumplir el objetivo la funcion moderar ya que no logro hacer que las cadenas sean identicas. Mi funcion de my_strequ funciona en otros programas pero no en este #include "my_string.h"
int moderar(char** a, int j, char** b, int c) { int i,k,l,m,w=0,cant=0; for(k=1; k<j; k++) { for(l=0;l<c;l++) { m=my_strequ(a[k],b[l]); if (m==1) { w=my_strlen((a[k])); int t=0; for(t=0; t<w; t++) { a[k][t]='x'; } } } cant+=w; } return cant; }
int main (int argc, char* argv[]) { char* palprob[TAM]; char auxi[30]; int i=0, nuevasx=0; int tama, cantpalprob=0; printf("\nIngresar hasta 10 palabras prohibidas a moderar (pulse ENTER si desea finalizar antes de llegar a 10 palabras):\n"); for (i=0;i<10 && *auxi!='\0';i++) { gets(auxi); cantpalprob=i; if (*auxi!='\0') { tama=my_strlen(auxi); palprob[i] = (char*) calloc (tama+1,sizeof(char)); my_strcpy(palprob[i],auxi); } } printf("Palabras prohibidas: ");
for(i=0; i<cantpalprob; i++) printf("\n\t\t\t%s ", palprob[i]);
nuevasx+= moderar(argv, argc, palprob, cantpalprob); printf("\nMensaje moderado: \n\t\t\t"); for(i=0; i<argc-1; i++) printf("%s ", argv[i+1]); printf("\n\nCantidad de caracteres modificados: %d \n\n",nuevasx); return 0; }
|
|
« Última modificación: 25 Junio 2014, 02:26 am por puppetz »
|
En línea
|
|
|
|
Eternal Idol
Kernel coder
Moderador
Desconectado
Mensajes: 5.969
Israel nunca torturó niños, ni lo volverá a hacer.
|
No, el problema esta en alguna de esas funciones my_, simplemente las reemplace por las standard y el programa funciono. En el bucle estas accediendo a un valor indefinido del primer caracter de auxi en la primera iteracion ...
|
|
|
En línea
|
La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste. Juan Domingo Perón
|
|
|
puppetz
Desconectado
Mensajes: 4
|
El programa funciona a la perfeccion! Gracias a Eternal y a Engel por su ayuda. Al final el problema estaba en my_strequ.
Saludos a todos
|
|
|
En línea
|
|
|
|
Eternal Idol
Kernel coder
Moderador
Desconectado
Mensajes: 5.969
Israel nunca torturó niños, ni lo volverá a hacer.
|
De nadas
|
|
|
En línea
|
La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste. Juan Domingo Perón
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
Segmentation fault (core dumped)
Programación C/C++
|
neveldine
|
3
|
5,665
|
3 Mayo 2012, 17:03 pm
por neveldine
|
|
|
Base de datos SQLite hace un Segmentation Fault al ejecutar sentencia SQL.
Programación C/C++
|
harry_the_blogger
|
2
|
2,083
|
19 Noviembre 2014, 16:50 pm
por ivancea96
|
|
|
segmentation fault en mi programa
Programación C/C++
|
:Luigi
|
3
|
5,042
|
30 Noviembre 2014, 23:37 pm
por :Luigi
|
|
|
(Ayuda) Segmentation fault sin razón aparente
« 1 2 »
Programación C/C++
|
class_OpenGL
|
11
|
6,207
|
15 Junio 2016, 06:29 am
por class_OpenGL
|
|
|
Segmentation Fault ayuda
Programación C/C++
|
GominaTilted
|
8
|
3,756
|
23 Marzo 2020, 02:08 am
por GominaTilted
|
|