Hola, que tal, soy un hombre de 26 años, la primera ves que yo entre a esta pagina web fue hace mas de 7 años, yo me habia registrado para entonces con otro nick, y bueno esta pagina me trae muchos recuerdos, pero vamos al punto.
Sucede que estoy intentando crear un programa en el lenguaje de programación C, pero necesito ayuda, ya que el programa tiene un problema, y es que durante el tiempo de ejecucion, luego de la compilacion, presenta un error.
Es un programa que crea un archivo de registros, y tambien lo lee e imprime su contenido en pantalla.
El problema esta al momento de imprimir en pantalla los registros creados en el archivo, ya que si usted crea el archivo con 5 registros, el programa va a imprimir 6 registros, es decir, siempre imprime un registro mas que no fue solicitado, y esto no es correcto, porque yo quiero que imprima el contenido del archivo, y no registros "fantasmas".
Asi que necesito a algun experto que me ayude.
Este es el codigo en cuestion
Un programa con dos funciones, CreateFile: crea un archivo con la cantidad de registros ingresada por el usuario; y ReadFile: lee un archivo e imprime en pantalla los registros que contiene ese archivo, parece ser que en esta funcion (ReadFile) es donde esta el problema pero no puedo comprender o encontrar el error
Hola después de entender mas o menos tu codigo y encontrar algunos detalles no veo bien cual sea el problema.
Hola amigo, gracias por responder, dios te bendiga, el problema esta en que la funcion ReadFile imprime en pantalla un registro adicional el cual no fue solicitado, por ejemplo si usted crea un archivo con 2 registros, ReadFile mostrara en pantalla 3 registros, de los cuales el tercero no tengo idea de donde habra salido; si usted crea el archivo con 3 registros, ReadFile mostrara 4,
Citar
hay un error porque si el archivo es creado con X numero de registros, esa cantidad es la que debe de mostrar, pero ReadFile esta mostrando X+1 registros
Citar
Si solo si escribes el archivo cuantos bytes pesa?
Pesa 20 bytes, segun windows, (quizas el tamaño varie segun el computador)
Detalles vistos:
Citar
En la funcion readfile el ciclo de inicialización sale sobrando.
¿Sobrando mi amigo querido?, usted dice que se desborda el buffer? de verdad que no entiendo porque si el array tiene 20 elementos, esta inicialización, la cual es solo para rellenar, en realidad sus valores no se usan, pues, no le veo nada de malo
Código
for(i=0;i<=19;i++)
{
if(i==19)
{
XRecord.Charac[i]='Y';
}
else
{
XRecord.Charac[i]='x';
}
}
Citar
Por que no usar fwrite para escribir toda la estrucuctura de golpe?
Primero estaba probando con fwrite y fread, pero como el programa continuo presentando el error, intente con fprintf y fscanf, para ver si se arreglaba, pero no se arreglo.
Citar
Ejemplos:
Saludos
Gracias por ese ejemplo AlbertoBSD, lo tomare en cuenta
¿Sobrando mi amigo querido?, usted dice que se desborda el buffer? de verdad que no entiendo porque si el array tiene 20 elementos, esta inicialización, la cual es solo para rellenar, en realidad sus valores no se usan, pues, no le veo nada de malo
me refiero a que : ¿Para que inicializar el buffer con datos? si al final vas a terminar sobreescribiendo sobre el con los datos desde el archivo.
He compilado el código y me ha dado unas cuantas advertencias. Deberías vigilarlas. Yo no voy a mostrar las advertencias pues lo puedes mirar tu mismo, pero aun así es preferible que un programa no las tenga, pues son potenciales errores que después cuesta solucionar (lo digo por experiencia).
Respecto al error, es bastante fastidiante (me ha pasado hace poco xD). Lo que pasa es que el indicador de feof se activa solo cuando se intenta leer un carácter pero ya no quedan más. Entonces, cuando terminas de leer el último registro, no llegas a activar el feof y por lo tanto el while se ejecuta una vez más.
Para solucionarlo, puedes comprobar que no has llegado al final del archivo antes de mostrar el supuesto registro:
Una solucion alterna a este problema es determinar la longitud del archivo y dividirlo entre el tamaño la estructura y asi solo leer el numero exacto de datos.
Gracias a los que respondieron, anotare sus nombres por alli para agredecerles cuando pueda, he resuelto el problema utilizando este codigo, sin embargo sus respuestas (AlbertoBSD, class_OpenGL, MAFUS), son muy utiles, ya que tambien resuelven el problema mediante codigos similares
Este es el que he usado, sustituyendo el while por este:
He compilado el código y me ha dado unas cuantas advertencias. Deberías vigilarlas. Yo no voy a mostrar las advertencias pues lo puedes mirar tu mismo, pero aun así es preferible que un programa no las tenga, pues son potenciales errores que después cuesta solucionar (lo digo por experiencia).
Respecto al error, es bastante fastidiante (me ha pasado hace poco xD). Lo que pasa es que el indicador de feof se activa solo cuando se intenta leer un carácter pero ya no quedan más. Entonces, cuando terminas de leer el último registro, no llegas a activar el feof y por lo tanto el while se ejecuta una vez más.
Para solucionarlo, puedes comprobar que no has llegado al final del archivo antes de mostrar el supuesto registro:
Una solucion alterna a este problema es determinar la longitud del archivo y dividirlo entre el tamaño la estructura y asi solo leer el numero exacto de datos.