![]() |
Entender las excepciones y Eurekalog?
Que tal Colegas, vengo intentando aprender a depurar con EUREKaLog.
Tenía errores de INVALID POINTER OPERATION, y leyendo en los foros encontré que se debía en su mayor parte a como se crean los forma. Siempre los creé de a siguiente forma (cortando del DPR los que no quiero en autocreate)
Entonces cambié todas esas creaciones por
Todo bien hasta que se me dio por probar pasar eurekalog Y resulta que me da que tengo 10 fugas. Y si no entiendo mal entre todo lo que figura me indica todos los CREATE.NIL Les adjunto un txt con el reporte de leaks. Y quisiera que me orienten, para ver si entiendo bien. En el LEAK1 todo lo que aparece en units propias de la vcl no son leaks no? Sólo lo que figura en units y forma creadas por mi verdad?. Como por ej en el leak1 figura la siguiente, que es donde hay un create.nil |00000002|04 |00000000|00D29311|TuSiVenXP.exe|00929311|principal |TFPrincipal |PresupuestosExecute |1414[1] TXT CON REGISTRO DE LEAKS Desde ya gracias por el espacio y su tiempo |
Hombre, forma correcta de crearlos es como dices, con una particularidad
Si las creas como:
Es el propio componente propietario el responsable de eliminar el objeto una vez se destruye. Sin embargo, si la creas así;
Al no tener propietario, no la libera nadie, con lo que ya tienes una fuga de memoria. La forma correcta de hacerlo siempre es liberándola tú, de esta forma Un saludo |
Eso quería entender. Muchas Gracias.
Al final en lugar de arreglar, he creado varias fugas, ya que cambié todas las sentencias Por pensando que era mejor. Pero así que e caso de usar nil, se usa con Try finnaly. Si uso CREATE(Owner). Está bien luego en el evento OnClose un
O se debe usar FreeAndNil que en algunos lados vi que sugieren. Que diferencia hay con CREATE(Self)? |
Cuando creas una instancia de componente, o formulario (los formularios también son componentes), el constructor te permite indicar qué otro componente es el dueño (propietario) de la nueva instancia de objeto. Ese dueño tendrá entonces ese nuevo componente en su lista de componentes adueñados, lista a la que podrás acceder mediante su propiedad Components. De tal suerte que, combinando el uso de esa propiedad con ComponentCount (cantidad de componentes adueñados), podrías realizar algún recorrido por cada uno de ellos, por ejemplo, para automatizar algún cambio sin necesidad de conocer previamente qué componentes son los que hay en la lista. Cuando el componente dueño se destruye, éste se encarga de destruir también la lista de componentes que posee, liberando la memoria de cada uno en orden inverso a su inclusión en la lista Components.
Cita:
, esencialmente estás construyendo un nuevo componente (MiNuevoObjeto) e instruyendo al objeto formulario (Self) para que lo incluya en su propiedad Components. Siendo "muy probable" que tras la ejecución de esa línea, la expresión Boolean sea verdadera. Pero no confíes mucho en esto último pues, dependiendo de cada caso, puede que el constructor de un componente esté programado para desencadenar la creación interna de otros objetos más, incluso con la particularidad de que esos otros objetos sean también componentes y queden bajo la tutela del mismo Owner. Así, MiNuevoObjeto podría quedar realmente en la casilla Components [ComponentCount - 2], Components [ComponentCount - 3], etc. Abundé en el tema para refrescar un poco la mente, pero que sea de utilidad mi aportación. :-) Saludos. Al González. |
Muchas Gracias Al Gonzalez, muy completa tu explicación, casi es todo un curso.
Para finalizar la consulta, para cerrar los forms creados ¿basta con Action :Cafree en OnClose? O se deberia hacer freeandNil? |
Yo todos los forms los creo con
Ejemplo para un form Modal, usando caFree:
Ejemplo para un form Modal, usando caHide:
Ejemplo para un form NO Modal, es mejor que uses caFree; otra cosa es complicarse la vida:
|
Gracias a todos por sus aportes.
Yo siempre creé los forma así
Que era como el mismo delphi crea los forms automáticamente. Pero después leyendo había visto que esa forma acarrea leaks mas facilmente. |
No sé de dónde sacas que acarrea leaks más fácilmente; no estoy de acuerdo.
Pero cada uno tenemos nuestras formas preferidas de programar :) Cita:
|
Otra vez con lo mismo
Que tal compañeros
Yo sigo sin entender al EUREKLOG. Me encuentra MEMORY LEAK en la linea de creacion de este reporte de quickreport
El leak me lo marca en esa linea de creacion. (size 30) Pero ademas, me engancha 2 LEAKS mas dentro de las UNITS DE QUICKREPORT (TQRPRINTER size 1572, TQRStream size 76) Y al final mete otro LEAK asociado a mi exe |+Leak #4: Type=Data at $0B861110; Total size=24576; Count=1 | |-----------------------------------------------------------------------------------------------------------------------------------------------| |00000002|03 |00000000|004C86F7|project.exe|000C86F7|System.Classes |TMemoryStream |Realloc ¿existirán estos leaks? O serán fantasmas. Porque en esa sección de impresión nunca tuve errores. Y con el eureka pretendía optimizar un poco los recursos y que me ayude a testear. Pero hasta ahora ve errores donde yo no. aunque ojo SUELO ESTAR CORTO DE VISTA. |
| La franja horaria es GMT +2. Ahora son las 15:12:07. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi