FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Crear y Destruir Formularios - Forma Correcta
Hola a Todos...
Capaz esta pregunta ya esta contestada en el foro, la busque pero no encontré... Mi pregunta es la siguiente: Cual es la manera correcta de crear un formulario? Planteo el escenario:
Para Cerrar el formulario , tengo un ToolBar con un TWindowClose. Pero este no asigna Nil a la variable FormX. ¿Lo correcto seria que asigne nil a la variable FormX en el evento destroy? Y Porque en el Create de un Form, la Variable FormX es igual a Nil pero Self no? Cual es la diferencia? Ahora voy a contar porque me surgen estas dudas... Tengo una app con casi 300 formularios. en la mayoria de los formularios, en el create del mismo llamo a un procedimiento que me pinta los componentes de x color. Hasta acá sin problemas. Pero resulta que ahora he tenido que agregar nuevos formularios y se da que aveces abro este form nuevo (FormX) y en el procedimiento que pinta los componentes me arroja un access violation. O se me da que abro un determinado form y luego el FormX y arroja el AV. Llevo mas de una semana tratando de encontrar el porque con estos nuevos formularios se produce el error y no encuentro. Ya cree un proyecto nuevo, probé en otra pc, hice los formularios desde 0... Y nada el error persiste... Entonces empece a ver mas detalladamente y note que (Yo siempre utilice la variable Form, que crea automáticamente el formulario) la primera ves que entra el formulario al procedimiento que pinta FormX = Nil, ahora la segunda vez ( Osea, lo cierro con el botón de cerrar TWindowCloe) y si lo abro de nuevo FormX tiene cosas adentro, no viene con Nil. Puse FormX := Nil en el evento destroy del FormX y el problema se soluciono. Ahora me queda la gran incógnita y es lo que me come la cabeza, de porque el error solo con esos formularios. Llegue a pensar a al pasar algún tamaño de ejecutable o uso de memoria a lo mejor cambia la administración y por eso surge ahora el error.. la verdad no se... Y por eso es que viene mi pregunta... ahora estoy pensando que a lo menor la forma en la que estoy creando y destruyendo los formularios no es la correcta, aunque esto no me responda porque en 299 Formularios no da el error y en el 300 si...(Puse estos mismos formularios en proyectos aun mas grandes y el error no se da)
__________________
Saluda Atte Neeruu!!! :) Última edición por Neeruu fecha: 06-02-2018 a las 22:37:35. |
#2
|
|||
|
|||
Todo esto viene a raiz de lo publicado en este post:
http://www.clubdelphi.com/foros/showthread.php?t=92600
__________________
Saluda Atte Neeruu!!! :) |
#3
|
|||
|
|||
Hola... Como crean sus formularios....?????
__________________
Saluda Atte Neeruu!!! :) |
#4
|
||||
|
||||
Para empezar, yo uso poco los formularios tipo DMI, más que nada porque en el trabajo diario no me hacen falta. Pero tengo entendido que cuando creas una ventana "hija" en un MDI se crea, pero cuando la cierras NO SE DESTRUYE, sino que se esconde. En estos casos, revive con un "Show" y no con un nuevo create.
Cuando creo formularios "modales", elimino de estos la variable "Formx: TFormx" que se crea automáticamente. Prefiero crearlos y liberarlos yo mismo desde código (No hace falta decir que hay que quitarlos de la parte "Autocreate" de las opciones del proyecto). De todas formas no está de más echar un vistazo a La cara oculta de Delphi 4 que, en el capítulo 13, tiene un extenso tutorial sobre "Técnicas de Gestión de Ventanas" Saludos |
#5
|
||||
|
||||
Comentas muchas cosas y es un tema delicado.
Lo primero que te diría es que elimines la variable que se crea automáticamente en cada formulario, porque es una variable global que suele dar problemas. El que has comentado tú y otros similares. Crea tus propias variables de formulario donde las necesites. Una solución si debes reaprovecharlas es ponerlas a NIL cuando se destrruye el formulario tal y como has hecho.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#6
|
|||
|
|||
Naftali, gracias...
Conoces alguna documentación donde se hable lo que estoy preguntando... Ya mismo empezare a corregir el código de mi proyecto.... tengo para rato ... Si sabes de algún material de lectura, bienvenido... Saludos.
__________________
Saluda Atte Neeruu!!! :) |
#7
|
||||
|
||||
Específicamente de esto no, pero en el FTP tienes bastantes manuales de Delphi. Algunos incunables como "La Cara Oculta de Delphi".
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#8
|
||||
|
||||
Buen día,
Personalmente estoy de acuerdo con lo expresado por Roman en el post #9 del hilo que enlazo aquí Sin embargo hay una solucion que yo utilizo para evitar lidiar con los FreeAndNil, "releases" mal ubicados. y es la siguiente: 1) Creo un Tform1 que es el MDIform y un tform2 que es el MDIChild 2) Elimino la variable automática que crea el Tform2 (form2), como sugiere ElKurgan 3) en el evento onclose del Tform2 agrego la linea: Action:= caFree; 4) Para efectos de la prueba agrego dos botones u opciones de menú en el form1. a) el primer boton instancia formularios TForm2 sin asignarlos a variables (pues se liberarán con el Onclose.
b) el segundo crea un formulario asignado a una única variable llamada MyFormX
PERO...!!! éste útlimo código solo funcionará una vez pues el Action:=caFree, libera la memoria pero la variable queda asignada por tanto Assigned(MyformX) solo será falso la primera vez... entonces aqui utilizo un truco que me parece bastante seguro: Utilizo una variable de clase para indicar si el formulario está instanciado o no
y en el Form1 cambio el llamado al boton:
De ésta manera quedan asi los códigos Form1:
Form2:
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
forma de programar no se si es la correcta ? | gulder | MySQL | 4 | 05-04-2016 17:49:51 |
Liberar Tlist de forma correcta | BDWONG | Varios | 3 | 01-11-2014 17:28:46 |
Forma correcta de conectar a la base.. | linuxtin | Conexión con bases de datos | 4 | 19-07-2012 20:30:20 |
Crear formularios de forma dinamica | istradlin | Lazarus, FreePascal, Kylix, etc. | 4 | 06-12-2007 15:30:40 |
Como destruir o liberar una forma | maguib | Varios | 1 | 11-03-2005 19:39:02 |
|