Angel Fernández
08-03-2008, 00:44:37
Hola a todos. Quisiera consultaros un problemilla que tengo.
Tengo una aplicación que recoge datos de un archivo de texto donde los datos están separados por puntos y comas (fichero .csv) y los guarda en una base de datos firebird.
Para ello utilizo un código que amablemente me ofreció Tocomi en este hilo (http://www.clubdelphi.com/foros/showthread.php?t=53508). Esto funciona perfectamente (gracias Tocomi).
El problema es que los archivos csv son inmensos (35000 líneas con 40 columnas) y el proceso (leer datos, convertir, comprobar, guardar etc.) lleva mucho tiempo y utiliza al 100% la cpu.
Para expresarme mejor, son 2 problemas juntos:
1. Lleva mucho tiempo.
2. Durante ese tiempo usa la cpu al 100%.
Si solvento el problema 2 poniendo un sleep(500) en cada línea para que respire la cpu, el problema 1 se me agudiza, llegando a tardar cerca de 30 minutos.
Si no pongo el sleep(xx), el tiempo baja considerablemente pero el consumo de cpu es, ya digo, del 100% todo el tiempo.
¿Qué es mejor? ¿Menos tiempo con uso de 100% de la cpu o mucho más tiempo con consumo de cpu del 20%? O, quizá una solución intermedia: ¿le pregunto al usuario qué prefiere y según su contestación pongo el sleep?
Un uso del 100% de la cpu lo hacen algunos programas de cálculo muy intenso, por ejemplo lame encoder cuando convierte de wav a mp3. Esto lo pongo como ejemplo que yo conozco.
Agradecería vuestros comentarios.
Saludos al foro.
Tengo una aplicación que recoge datos de un archivo de texto donde los datos están separados por puntos y comas (fichero .csv) y los guarda en una base de datos firebird.
Para ello utilizo un código que amablemente me ofreció Tocomi en este hilo (http://www.clubdelphi.com/foros/showthread.php?t=53508). Esto funciona perfectamente (gracias Tocomi).
El problema es que los archivos csv son inmensos (35000 líneas con 40 columnas) y el proceso (leer datos, convertir, comprobar, guardar etc.) lleva mucho tiempo y utiliza al 100% la cpu.
Para expresarme mejor, son 2 problemas juntos:
1. Lleva mucho tiempo.
2. Durante ese tiempo usa la cpu al 100%.
Si solvento el problema 2 poniendo un sleep(500) en cada línea para que respire la cpu, el problema 1 se me agudiza, llegando a tardar cerca de 30 minutos.
Si no pongo el sleep(xx), el tiempo baja considerablemente pero el consumo de cpu es, ya digo, del 100% todo el tiempo.
¿Qué es mejor? ¿Menos tiempo con uso de 100% de la cpu o mucho más tiempo con consumo de cpu del 20%? O, quizá una solución intermedia: ¿le pregunto al usuario qué prefiere y según su contestación pongo el sleep?
Un uso del 100% de la cpu lo hacen algunos programas de cálculo muy intenso, por ejemplo lame encoder cuando convierte de wav a mp3. Esto lo pongo como ejemplo que yo conozco.
Agradecería vuestros comentarios.
Saludos al foro.