problemilla en c++

Iniciado por pABL012, 3 Septiembre 2013, 19:21 PM

0 Miembros y 3 Visitantes están viendo este tema.

pABL012

Hola a todo el que lo lea.
Escribo en el foro a causa de un programa que he escrito en lenguaje c++. La causa es que tengo un problema y tras una búsqueda algo ligera con la ayuda de san google, no he encontrado a nadie que tuviese el mismo problema que yo.
He aquí el problema:
Al ejecutar el programa, tras estar un tiempo funcionando, este se cierra drásticamente. La solución no es poner un getchar() al final ni nada parecido. El programa funcionaba bien hasta que añadí algunas líneas de código. Al compilar no avisa de ningún error ni tampoco "warnings". Dado que el programa tiene unas 2000 líneas netas, no veo plausible el poner el código. La respuesta que busco son las razones por las que un ejecutable podría terminar su ejecución de forma drástica sin haber llegado al final del programa, y en un segundo plano las claves para solucionarlo.

Un saludo y muchas gracias de antemano.

Eternal Idol

Acceder a un puntero invalido es un ejemplo pero no vale la pena teorizar en estos casos, lo que tenes que hacer es  depurar tu programa, te recomiendo usar el WinDbg.
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

pABL012

Gracias por la respuesta. Voy a probar con esto que me dices.

Un saludo.

Alien-Z

Cita de: Eternal Idol en  3 Septiembre 2013, 19:26 PMlo que tenes que hacer es  depurar tu programa, te recomiendo usar el WinDbg.

CitarEl programa funcionaba bien hasta que añadí algunas líneas de código.

Aunque es evidente te comento que deberías empezar por depurar la zona de código que añadiste y, si no se soluciona, continúa por funciones, métodos y rutinas que sean llamadas por dichas líneas.

Saludos.

amchacon

Un método (algo chapuzero) es poner un getchar() al principio del codigo, si funciona hasta el getchar() ve avanzando. De esa forma identificaras la línea que da problemas.

Lo más probable que sea algún puntero.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

pABL012

Hola otra vez.
Gracias por todas las respuestas, pero no he logrado resolver el problema. Con la ayuda de WinDbg si he podido saber que el problema se debe a un "stack overflow", pero no logro encontrar el lugar donde sucede. ¿Hay algún método para que WinDbg me diga en qué línea de código se encontraba cuando se produce el overflow?
En realidad ojalá fuese tan fácil como colocar un getchar(), pero en mi caso se trata de un programa de estadística: lo que hago es repetir una cosa muchas veces y a partir de muchos resultados sacar conclusiones, por lo que puedo pasar 40 veces por una línea y no obtener ningún fallo, pero a la que hace 41...

En fin que lo que me está llevando de cabeza es el encontrar la línea en la que se produce el overflow. Si a alguien se le ocurriese algo le estaría muy agradecido.

Un saludo.

Eternal Idol

Un stack overflow no se produce en una linea util digamos, la ultima instruccion que mueva algo a la pila sera la que termine por explotar PERO el problema esta en todas las anteriores, dale un kb ffff para ver la pila completa. ¿Estas usando alguna funcion recursiva por casualidad?
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

pABL012

Vaya. Pues si, efectivamente estoy usando una función recursiva. Pero me parecería raro que fuese ahí el fallo porque únicamente le introduje unas variables nuevas que uso para comparar en condicionales...

eferion

Cita de: pABL012 en  5 Septiembre 2013, 12:13 PM
Vaya. Pues si, efectivamente estoy usando una función recursiva. Pero me parecería raro que fuese ahí el fallo porque únicamente le introduje unas variables nuevas que uso para comparar en condicionales...

Si los condicionales están mal diseñados y permiten que se sigua llamando de forma recursiva a la función cuando no deberían...

Tu piensa que cada llamada a una función supone meter datos en la pila. Una llamada recursiva que se llame a sí misma de forma descontrolada implica que la pila antes o después se va a desbordar... cuando eso pasa tu programa muere.

pABL012

Estoy seguro de que no se llama de forma descontrolada a la función. Como ya digo, el programa pasa por esas líneas unas 40 veces antes de morir... no se me ocurre que hacer, la verdad