FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Problema con flujo OFSTREAM
Qué tal compañeros., tengo una duda y agradecería cualquier comentario al respecto. En mi formulario principal (llamado frmStart), como variable pública, tengo la siguiente declaración:
ofstream ofPreviousTagged; En otra unidad (en otro .cpp aparte), abro el flujo: Código:
frmStart->ofPreviousTagged.open (previousTagged.c_str()); if (!frmStart->ofPreviousTagged) { Application->MessageBox ("No se puede abrir archivo para escribir etiquetas.", "PREVIOUS-TAGGED file not found", MB_OK | MB_ICONERROR); exit (0); } Código:
frmStart->ofPreviousTagged << actual->realWrd << " " << actual->pos << " " << actual->comment << "\n"; while (actual->next!=NULL) { actual = actual->next; frmStart->ofPreviousTagged << actual->realWrd << " " << actual->pos << " " << actual->comment << "\n"; } Quieres querer VMIP2S0 un un TIMS0 refresco refresco NCMS000 Corriendo la aplicación paso a paso he notado que las variables actual->realWrd, actual->pos y actual->comment, sí tienen sus valores correspondientes, pero después de que escriben voy al archivo y únicamente en él está escrito la letra Q (que corresponde a la primer letra de la primer oración), y ya no me escribe nada más. ¿Por qué únicamente me escribe un caracter? La idea de tener declarado el flujo en el formulario principal, es por facilidad de manejo y otros detalles que no vale la pena mencionar. De antemano muchas gracias, saludos. Última edición por dec fecha: 05-09-2005 a las 20:27:10. Razón: (Encerrar el código fuente en la etiqueta CODE) |
#2
|
||||
|
||||
Bien.........empecemos.........
"actual" es una lista enlazada? parece serlo. En vez de Código:
if (!frmStart->ofPreviousTagged) Código:
if (!frmStart->ofPreviousTagged.is_open()) Código:
#pragma hdrstop #pragma argsused #include<iostream> #include<fstream> //.................................. { using namespace std; ofstream ofPreviousTagged; ofPreviousTagged.open(previousTagged.c_str()); if(!ofPreviousTagged.is_open()) { Application->MessageBox ("No se puede abrir archivo para escribir etiquetas.", "PREVIOUS-TAGGED file not found", MB_OK | MB_ICONERROR); exit (0); } ofPreviousTagged<<"Hola\n"; ofPreviousTagged.close(); return; }
__________________
Los Estados Unidos parecen destinados por la Providencia para plagar la América de miserias a nombre de la libertad." Simón Bolívar (Carta al Coronel Inglés Patricio Cambell 05/08/1829). Última edición por OSKR fecha: 06-09-2005 a las 16:38:42. Razón: (Encerrar el código fuente en la etiqueta CODE) |
#3
|
||||
|
||||
No es muy recomendable que un archivo se declare en un lado, se habra en otro y se modifique en otro.
Podrias tener graves problemas. Es mejor diceñar una sola clase que se encargue de manipular el archivo.
__________________
[Crandel] |
#4
|
|||
|
|||
Hola! Bien, muchas gracias por sus comentarios, ambos tienen la razón. Referente al primero, sí, tienes razón, lo que pasa es que omití indicar que el programa me truena, entonces voy al archivo y sólo está grabada la letra Q, pero si lo cierro antes de que truene el programa, entonces sí se graban los demás datos. Implemento ahora los método GOOD() y IS.OPEN().
Respecto al segundo comentario, tienes razón, lo que hago ahora es en una sola clase manejar la apertura, cerrado y grabado de datos en el flujo, a través de métodos. Ahora bien, tengo como duda el por qué el programa me truena. Sí, en el archivo escribo alrededor de 800 palabras y de pronto... cuando intento grabar más datos al flujo me sale el error de que se hace referencia a una posición de memoria no válida. A ver, seré más claro. En una clase defino el flujo, y declaro métodos para grabar datos en él, cerrarlo, etc etc. El método para grabar datos es: Código:
void TfrmStart::WritePreviousTagged (String w, String p, String c) { ofPreviousTagged << w.c_str() << " " << p.c_str() << " " << c.c_str() << endl; } Código:
while (actual->next != NULL) { actual = actual->next; frmStart->WritePreviousTagged(actual->realWrd, actual->pos, actual->comment); } Código:
void TfrmStart::WritePreviousTagged (String w, String p, String c) { try { ofPreviousTagged << w.c_str() << " " << p.c_str() << " " << c.c_str() << endl; } catch (...) { Close_ofPreviousTagged(); Open_ofPreviousTagged(); } } Última edición por nax fecha: 07-09-2005 a las 03:47:10. |
#5
|
||||
|
||||
No estoy seguro! pero creo q en tal caso seria problema de la lista enlazada
ese "actual = actual->next;" me asusta, el hecho de q valide no encontrar o acceder una posicion nula no garantiza q esa referencia sea valida, solo es valida si ha sido asignada dinamicamente o tomada de una estatica, perfectamente la lista puede llegar y mandar el desplazamiento correspondiente a la cadena String q envias como parametro en la funcion pero cuando se acceda te arrojara la excepcion, verifica bien la implementacion de la lista
__________________
Los Estados Unidos parecen destinados por la Providencia para plagar la América de miserias a nombre de la libertad." Simón Bolívar (Carta al Coronel Inglés Patricio Cambell 05/08/1829). |
|
|
|