Saber cuanto ocupa un objeto en memoria
Buenos días,
hay alguna forma de saber lo que ocupa un objeto creado en memoria? Me explico. Si tengo este código:
Da igual cuantos objetos añada a la Lista del objeto a que siempre me va a devolver 16 bytes. Que es la suma de 4 bytes del puntero a la clase, + 4 del String, +4 del entero + 4 del puntero a la objectlist. Pero esa objectlist e incluso el string pueden variar en tamaño. Como puedo saber realmente lo q ocupa en un momento dado???? |
hola, echale un vistazo a la funcion sizeof (aunque ahora mirando la ayuda no estoy seguro si te dara el tamaño del objeto o del puntero...:confused:). Saludos.
|
Está complicado...
no creo que eso sea tarea sencilla. Es muy necesario? hay alguna que otra estructura interna en los objetos como ser la VMT.
Necesitas saber la instancia o los datos de la instancia? De ser esto último, las propiedades "published" y "Stored" es suficiente? si es así, bastará con recorrer el objeto Rtti mediante... también debes recorrer a todo lo persistente que cuelgue de él. |
Hola AFilth.
Te hago las mismas preguntas que Poyo, solicitándote que nos plantees cuál es el propósito de conocer el tamaño de toda la rama de datos (o aclares si es otra cosa lo que buscas). ¿Algo que ver con el almacenamiento de los mismos en algún medio? Danos más detalles de tu caso, por favor. :) Cita:
Sin adentrarnos más en el lado "tenebroso" del compilador, te invito a dar algo más de contexto sobre tu caso. Saludos. Al González. :) |
Se me ocurre una idea, serviría escribir todo el contenido del objeto a un TStream y luego obtener el tamaño de este Stream?
Saludos. |
Cita:
Saludos. :) |
Cita:
para saber cuanto consume de memoria su programa, al hacer varias operaciones del mismo tipo que nos pone de ejemplo. y hacer un bien programa que consuma pocos recursos sea eficiente. ¿yo tambien me pregunto como medir la memoria que consume mis programas? |
Cita:
|
Tal como Al comentaba, es un problema porque en el proceso de persistencia (streaming o como se llame) no sólo está limitado a propiedades Públicas sino que, ademas, son convertidas a String:
Un bitmap es convertido a Hexadecimal... esos datos terminan ocupando el doble, los colores veces son traducidos a nombres, los enteros en raras oportunidades ocupan los 4 bytes que ocupan en memoria... Además, algunas propiedades no se guardan (con el valor por default), también no se tiene en cuenta cosas la alineación con la memoria, estruturas empaquedas o no... en otras palabras, no tiene nada que ver con lo que ocupa en memoria. Mi instinto me dice que si se quiere saber REALMENTE cuánto ocupa algo en memoria es muy muy difícil, al menos bajo este marco de trabajo (delphi/cbuilder). Tal vez, si se conoce muy por dentro TODO el funcionamiento de del sistema (Rtl, Vcl, compilador y un largo etc.), hookeando la función de memory allocation (no me viene en castellano) como lo hace el Fast Memory Manager e ir recopilando y ordenando la información, sea factible... pero se me hace que es una tarea importante. A lo mejor se puede hacer más sencillamente, peor mucho no se me ocurre cómo. Y, como si fuera poco, si así y todo logramos implementar alguna solución a semejante incógnita (ya me picó el bichito de la curiosidad nuevamente. jejeje) nos vamos a encontrar con un problema aun mayor, que nos va a dar por el c**o! saben a qué me refiero??? http://www.unex.es/~fan/cuantica/mc%...heisenberg.htm qué dramaturgo soy! pero es verdad... snif snif... bueno, al menos hasta que se compruebe lo contrario, no? ;) pero claro... no nos vayamos por las ramas (perdón, confieso.. fui yo! :() ... y, como ya se dijo, esperemos a que AFilth conteste lo antes preguntado. |
Cita:
http://www.clubdelphi.com/foros/showthread.php?t=9764 Un abrazo subatómico. Al. :) |
Al, si bien esto se está tornando "Off topic", he leido tu mensaje y me puse de inmediato a ello... curiosidad, vio?
Así que decidí habrir otro nuevo hilo para que este no se vaya por las ramas: http://www.clubdelphi.com/foros/showthread.php?p=336279 |
La franja horaria es GMT +2. Ahora son las 04:51:08. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi