![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
|||
|
|||
|
Hola de nuevo y gracias a los dos por la ayuda.
Estoy ya implementando vuestros consejos, aunque como el código estaba muy extendido ya, me queda todavía, y no se aún si funciona. Me estoy planteando tener una función/ o método 'ordenar', que trate de manera aislada el TList para ordenar y luego devuelva una copia del TList pero pasado a 'array or record' que es lo que usa el resto de partes del programa. Además, todavía me quedan algunas dudas... 1. Sobre la llamada a ordenar: ¿Puedo pasar en vez de una función, un método de clase? Also como '@self.compararCampo1'. Para no tener funciones sueltas. He probado pero no he conseguido salvar el error 'variable expected'. 2. Sobre el destruir items de la lista. Cita:
También tengo otro problema, y es que tengo que almacenar cada Tlist que proceso en un array (array of TList). Resulta que cada vez que voy a procesar un nuevo TList, lo libero (reseteo), y pierdo lo que tenia almacenado en el array de TList de anteriores posiciones. Pero para no mezclar, esto lo trataré en un nuevo Post si es necesario. Saludos. Última edición por Bauhaus1975 fecha: 28-02-2009 a las 19:33:36. |
|
#2
|
||||
|
||||
|
Cita:
Si no me equivoco es indiferente. Tengo entendido que Items es la propiedad vectorial por defecto que tiene TList. Por ello es que es lo mismo: Lista[] que Lista.Items[]. Saludos, |
|
#3
|
||||
|
||||
|
A ver, no nos confundamos. El método Lista.Delete borra un elemento de la lista, pero cada elemento es un puntero y Delete no libera la memoria a la que apunta el item, es decir, el registro creado con New. Por eso es necesario Dispose.
Igualmente, el método Lista.Clear únicamente borra cada item, pero sin liberar la memoria a la que apunta cada uno. Por eso escribí: antes de destruir la lista. Es decir, tienes que hacer el Dispose de cada elemento, y posteriormente llamar a Lista.Free para borrar la lista y todos sus elementos. En resumen: una cosa es el puntero y otra cosa es el bloque al que apunta el puntero. // Saludos |
|
#4
|
|||
|
|||
|
Hola de nuevo.
Ey Delphius, gracias por el apunte. Entendido, la liberación de memoria de cada elemento de la lista hay que programarla. Y sobre pasar un método de clase ¿puede hacerse?:
Gracias y un saludo. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Ordenar un array | Aldaya | Varios | 2 | 27-11-2007 09:45:00 |
| Ordenar array ???? | burasu | Varios | 6 | 15-02-2007 20:39:16 |
| Encontrar un registro determinado. | alfredosg19 | Conexión con bases de datos | 3 | 20-06-2005 21:09:49 |
| Borrar un dato determinado de un Array. | alfredosg19 | Varios | 5 | 24-03-2005 10:05:17 |
| Ordenar un array de records | Feñiz | OOP | 7 | 04-02-2005 08:19:28 |
|