Ver Mensaje Individual
  #7  
Antiguo 12-06-2005
Mick Mick is offline
Miembro
 
Registrado: may 2003
Posts: 405
Reputación: 22
Mick Va por buen camino
En cuestion de rendimiento hay dos cosas a tener en cuenta, por un lado la cantidad de memoria que se utilice, y por otro la velocidad de acceso a los datos.

Uso de memoria:

Un TStringList en principio no tiene limitacion de memoria, el limite lo pone la arquitectura de los PCs y la cantidad de memoria ram que tenga el equipo, puedes guardar hasta 2^30 elementos, unos mil millones aproximadamente.

Puedes hacer tu mismo una estimacion de la memoria RAM que se necesitara, poniendote en el peor caso, por ejemplo para 10.000 elementos , si suponemos que cada elemento tuviese de 255 caracteres de largo, necesitariamos mas o menos: sobre (255+16)*10.000 = 2.5 megas de RAM.

Velocidad de acceso:

Si se necesitan hacer busquedas no exactas sobre todos los elementos, es necesario recorrer la lista entera, esta es la forma mas lenta de acceso, pero para unos pocos miles de elementos normalmente es casi instantaneo.

Para una busqueda exacta puedes mantener la lista ordenada, (El objeto TSTringList se puede mantener ordenado automaticamente por si mismo, ya que implementa internamente el algoritmo quicksort).

En definitiva segun mi opinion:

Si los elementos son unos pocos miles, un stringlist puede ser mas que suficiente, si los elementos fuesen cientos de miles o millones, ya no nos cabrian todos en memoria ademas de que las busquedas se harian mas lentas, y en ese caso necesitariamos utilizar una base de datos o hacerse un mini gestor de base de datos propio para no tener cargada a memoria toda la informacion.

Saludos
Miguel
Responder Con Cita