Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 07-03-2005
manuelpr manuelpr is offline
Miembro
 
Registrado: nov 2003
Posts: 30
Poder: 0
manuelpr Va por buen camino
Thumbs up Consejo para Acelerar Procesos

Tengo un proceso que Lee (en forma secuencial) tablas DBF y encuentro que se demora demaciado. Alguien sabe como puedo acelerar la lectura de estas tablas

Gracias
Responder Con Cita
  #2  
Antiguo 08-03-2005
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Smile

¡Buen día a todos!

Manuelpr:

Existen diversas formas de acelerar procesos de software. Una de ellas es cambiar el hardware (procesador más rápido, más memoria RAM, etc.). Sin embargo, casi siempre es más económico optimizar el software (sobre todo cuando el programador recibe bajos honorarios ), lo cual implica revisar el código fuente con que se cuente y hacerlo más eficiente.

Por ejemplo, si tienes un bloque de código como este:
Código Delphi [-]
...
Begin
  If Tabla.Locate ('Nombre', Tabla2Nombre.Value, []) Then
    If X > Pos ('A', Data) Then
      ShowMessage ('¡Hola mundo!')
    Else
      If Pos ('A', Data) > 0 Then
        ShowMessage ('¡Hola planeta!')
      Else
        ShowMessage ('¡Hola Tierra!')
  Else
    ShowMessage ('¡Hola a todos!');

  If Tabla.Locate ('Nombre', Tabla2Nombre.Value, []) And (X > 10) Then
    ShowMessage (IntToStr (Pos ('A', Data)));
End;
...
quedaría más óptimo (su compilado ejecutable correría más rápido) de esta manera:
Código Delphi [-]
...
Var
  Existe :Boolean;
  Posicion :Integer;  
Begin
  Existe := Tabla.Locate ('Nombre', Tabla2Nombre.Value), []);
  Posicion := Pos ('A', Data);

  If Existe Then
    If X > Posicion Then
      ShowMessage ('¡Hola mundo!')
    Else
      If Posicion > 0 Then
        ShowMessage ('¡Hola planeta!')
      Else
        ShowMessage ('¡Hola Tierra!')
  Else
    ShowMessage ('¡Hola a todos!');

  If Existe And (X > 10) Then
    ShowMessage (IntToStr (Posicion));
End;
...

En el primer caso se llama a las rutinas
  • Tabla.Locate: 2 veces
  • Pos: 3 veces

En el segundo caso se llama a las rutinas
  • Tabla.Locate: 1 sóla vez
  • Pos: 1 sóla vez

En el segundo caso se ocupa más memoria que en el primero (por las variables auxiliares Existe y Posicion), pero es justificable desde el punto de vista costo-beneficio, concepto que en programación casi siempre está representado por la relación espacio-velocidad.

Espero esto sea de utilidad, seguimos en contacto.

Al González.

Última edición por Al González fecha: 08-03-2005 a las 06:54:58.
Responder Con Cita
  #3  
Antiguo 08-03-2005
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.276
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por manuelpr
Tengo un proceso que Lee (en forma secuencial) tablas DBF y encuentro que se demora demaciado.
Tal vez si pones el código que estás utilizando podamos darte algun consejo, si él es difícil...
__________________
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.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 16:27:11.


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
Copyright 1996-2007 Club Delphi