Muchas gracias paquitohm, lo vi en su día, lo volveré a mirar.paquitohm wrote:Buenos días,
El blog de Rafa aún sigue aportando mucho.
Si tiras del hilo podrás profundizar en tema hilos https://xthefull.blogspot.com/2016/07/t ... vatos.html
Multihilo - Multithread
Re: Multihilo - Multithread
Un Saludo
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
-
- Posts: 55
- Joined: Tue Feb 09, 2021 4:20 pm
Re: Multihilo - Multithread
Multithread es como tener múltiples EXEs.
De esta manera es claramente visible.
https://www.youtube.com/watch?v=KwK2DrLjc8A
Tenga en cuenta que si cierra el proceso principal, se cierra todo (se no haces nada diferente).
Mi uso de fivewin es así, desde una aplicación gtwvg, estoy empezando con la conversión.
No probé solo con fivewin.
De esta manera es claramente visible.
https://www.youtube.com/watch?v=KwK2DrLjc8A
Tenga en cuenta que si cierra el proceso principal, se cierra todo (se no haces nada diferente).
Mi uso de fivewin es así, desde una aplicación gtwvg, estoy empezando con la conversión.
No probé solo con fivewin.
Re: Multihilo - Multithread
Y cómo harían Ustedes para que un Timer se ejectuara en un hilo diferente.
Yo tengo este código:
¿Cómo hago para que este Timer se ejecute en su propio Hilo?
¿O debo crear el Hilo dentro de la función lVFLaunchVerifactu() ?
Muchas gracias,
Yo tengo este código:
Code: Select all | Expand
DEFINE TIMER oVFTimer1 OF oVFWndTimer INTERVAL ( 1000 * nDelay ) ACTION ( oVFTimer1:Deactivate(), ;
lVFLaunchVerifactu( AMPAARRA, uSetGetValInArrBD( AMPAARRA, Nil, 84, Nil ) ), ;
oVFTimer1:Activate() )
¿O debo crear el Hilo dentro de la función lVFLaunchVerifactu() ?
Muchas gracias,
Un Saludo
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
- Antonio Linares
- Site Admin
- Posts: 42386
- Joined: Thu Oct 06, 2005 5:47 pm
- Location: Spain
- Has thanked: 8 times
- Been thanked: 14 times
- Contact:
Re: Multihilo - Multithread
Estimado Carlos,
Una reflexión apropiada sería distinguir lo que hace un timer de lo que hace un "hilo de ejecución" y ver hasta que punto son compatibles y deseable el usarlos juntos.
Un timer hace que cada x tiempo se genere un evento desde el cual se ejecuta un proceso. Es decir, todo se para hasta que se completa la ejecución de ese proceso.
Un "hilo de ejecución" lo que hace es "bifurcar" (un tanto artificialmente) la ejecución principal del programa. Es decir, es como si en vez de existir una CPU, existiesen más de una CPU. En realidad la CPU principal "reparte" el tiempo entre cada proceso, aunque a todos los efectos pareciese que se ejecutan en paralelo.
Finalmente la pregunta es: ¿ Que es lo que necesitas hacer para saber que camino tomar ?
Una reflexión apropiada sería distinguir lo que hace un timer de lo que hace un "hilo de ejecución" y ver hasta que punto son compatibles y deseable el usarlos juntos.
Un timer hace que cada x tiempo se genere un evento desde el cual se ejecuta un proceso. Es decir, todo se para hasta que se completa la ejecución de ese proceso.
Un "hilo de ejecución" lo que hace es "bifurcar" (un tanto artificialmente) la ejecución principal del programa. Es decir, es como si en vez de existir una CPU, existiesen más de una CPU. En realidad la CPU principal "reparte" el tiempo entre cada proceso, aunque a todos los efectos pareciese que se ejecutan en paralelo.
Finalmente la pregunta es: ¿ Que es lo que necesitas hacer para saber que camino tomar ?
- Antonio Linares
- Site Admin
- Posts: 42386
- Joined: Thu Oct 06, 2005 5:47 pm
- Location: Spain
- Has thanked: 8 times
- Been thanked: 14 times
- Contact:
Re: Multihilo - Multithread
Tiene sentido lo que preguntas
El evento del timer solicitaría que se ejecute un proceso, pero el proceso se ejecutaría en un hilo diferente para no enlentecer la ejecución de la app principal.
Es este el efecto que buscas ?
El evento del timer solicitaría que se ejecute un proceso, pero el proceso se ejecutaría en un hilo diferente para no enlentecer la ejecución de la app principal.
Es este el efecto que buscas ?
- Antonio Linares
- Site Admin
- Posts: 42386
- Joined: Thu Oct 06, 2005 5:47 pm
- Location: Spain
- Has thanked: 8 times
- Been thanked: 14 times
- Contact:
Re: Multihilo - Multithread
Simplemente así:
Si usas hbmk2 para construir tu app (es lo más recomendable) recuerda usar el flag -mt para que se construya con soporte de ejecución multihilo
Ojo con el uso de variables compartidas y de DBFs ya que tendrás que usar "mutex"es (semáforos) para aplicar la prioridad deseada.
Code: Select all | Expand
DEFINE TIMER oVFTimer1 OF oVFWndTimer INTERVAL ( 1000 * nDelay ) ACTION hb_threadStart( { || lVFLaunchVerifactu( AMPAARRA, uSetGetValInArrBD( AMPAARRA, Nil, 84, Nil ) ) } )
Ojo con el uso de variables compartidas y de DBFs ya que tendrás que usar "mutex"es (semáforos) para aplicar la prioridad deseada.
- Carles
- Posts: 1149
- Joined: Fri Feb 10, 2006 2:34 pm
- Location: Barcelona
- Been thanked: 5 times
- Contact:
Re: Multihilo - Multithread
Bones,
Yo creo q quiere crear un pool de impresiones o imprimir en 2 plano mientras el progeama sigue con la suya. Si es asi lanzar un hilo para ejecurar la tarea y listos.
C.
Yo creo q quiere crear un pool de impresiones o imprimir en 2 plano mientras el progeama sigue con la suya. Si es asi lanzar un hilo para ejecurar la tarea y listos.
C.
Salutacions, saludos, regards
"...programar es fácil, hacer programas es difícil..."
UT Page -> https://carles9000.github.io/
Forum UT -> https://discord.gg/bq8a9yGMWh
Skype -> https://join.skype.com/cnzQg3Kr1dnk
"...programar es fácil, hacer programas es difícil..."
UT Page -> https://carles9000.github.io/
Forum UT -> https://discord.gg/bq8a9yGMWh
Skype -> https://join.skype.com/cnzQg3Kr1dnk
Re: Multihilo - Multithread
Pienso como Charly.
Además como la impresión no necesita ninguna tutela solo tienes que enviarlo a un subhilo y te olvidas, De hecho deberías tener solo un hilo de impresion al cual enviar las peticiones para el trabajo de imprimir.
Pero para procesos repetitivos en el tiempo, el Timer debería estar en el principal.
Además como la impresión no necesita ninguna tutela solo tienes que enviarlo a un subhilo y te olvidas, De hecho deberías tener solo un hilo de impresion al cual enviar las peticiones para el trabajo de imprimir.
Pero para procesos repetitivos en el tiempo, el Timer debería estar en el principal.
______________________________________________________________________________
Sevilla - Andalucía
Sevilla - Andalucía
Re: Multihilo - Multithread
Hola todos,
El caso práctico es que es una aplicación de facturación que cada 'n' segundos enviará la información ( shellexecute(CURL.EXE) ) de las nuevas 'facturas' a Verifactu.
Es decir, una aplicación que deseo que mientras el usuario hace sus labores habituales, no note que hay un proceso que está enviando información a Verifactu.
Tal como dice Antonio.
Por otro lado, de las DBF usadas en ese proceso, unas sólo las actualiza ese mismo proceso, otras sólo las lee y una última es alimentada por el 'usuario' añadiendo datos de facturas desde el proceso de facturación. Todas se abren (Shared en todos los procesos de la aplicación) y cierran en este proceso y con alias diferentes.
Y de la variables 'compartidas', no se actualiza ninguna en ese proceso y normalmente en otros procesos 'habituales' tampoco. Son de configuración.
Hoy en día estoy compilando con un make.rmk con las lib -mt, aunque no lo estaba usando.
A ver si hoy o mañana pruebo como va.
Muchas gracias a todos.
El caso práctico es que es una aplicación de facturación que cada 'n' segundos enviará la información ( shellexecute(CURL.EXE) ) de las nuevas 'facturas' a Verifactu.
Es decir, una aplicación que deseo que mientras el usuario hace sus labores habituales, no note que hay un proceso que está enviando información a Verifactu.
Tal como dice Antonio.
Por otro lado, de las DBF usadas en ese proceso, unas sólo las actualiza ese mismo proceso, otras sólo las lee y una última es alimentada por el 'usuario' añadiendo datos de facturas desde el proceso de facturación. Todas se abren (Shared en todos los procesos de la aplicación) y cierran en este proceso y con alias diferentes.
Y de la variables 'compartidas', no se actualiza ninguna en ese proceso y normalmente en otros procesos 'habituales' tampoco. Son de configuración.
Hoy en día estoy compilando con un make.rmk con las lib -mt, aunque no lo estaba usando.
A ver si hoy o mañana pruebo como va.
Muchas gracias a todos.
Un Saludo
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
Re: Multihilo - Multithread
Hola,
Ese tipo de situaciones lo he solucionado rellamando al ejecutable con un parametro para que haga una funcion especifica
En este caso, en el timer, pondria una llamada al ejecutable asi o parecido RUN Algo.exe /ENVIO_VERIFACTU y en el main cogeria el parametro
Esto asegura una correcta comparticion de recursos
Sin duda que el uso de thread es más elegante, pero quizás no más practico. ¿ Que es más elegante y qué es más practico ? ¿ Un coche electrico o un coche de combustion ? Pues eso
Ese tipo de situaciones lo he solucionado rellamando al ejecutable con un parametro para que haga una funcion especifica
En este caso, en el timer, pondria una llamada al ejecutable asi o parecido RUN Algo.exe /ENVIO_VERIFACTU y en el main cogeria el parametro
Esto asegura una correcta comparticion de recursos
Sin duda que el uso de thread es más elegante, pero quizás no más practico. ¿ Que es más elegante y qué es más practico ? ¿ Un coche electrico o un coche de combustion ? Pues eso
Re: Multihilo - Multithread
Yo tengo 3 escenarios y 3 soluciones, 2 funcionan y la tercera está en desarrollo.
a) Un puesto que factura algunas veces a la semana: Verifactu funcionando según se emite factura (on line).
b) Varios puestos que pueden facturar: Verifactu es un ejecutable que se lanza al arrancar el SIF ( des de la aplicación 'principal' Shellexecute( loquesea.exe ) o manualmente desde el escritorio Windows) y que va buscando según un Timer.
c) Aplicación SIF externa que dejará información en unas DBF, y un ejecutable externo que capturará esta información y hará toda la gestión para enviar a Verifactu, buscará según un Timer. El SIF y Verifactu son de desarrolladores diferentes. Esta solución la quiero entregar antes de Navidad.
Seguimos,
a) Un puesto que factura algunas veces a la semana: Verifactu funcionando según se emite factura (on line).
b) Varios puestos que pueden facturar: Verifactu es un ejecutable que se lanza al arrancar el SIF ( des de la aplicación 'principal' Shellexecute( loquesea.exe ) o manualmente desde el escritorio Windows) y que va buscando según un Timer.
c) Aplicación SIF externa que dejará información en unas DBF, y un ejecutable externo que capturará esta información y hará toda la gestión para enviar a Verifactu, buscará según un Timer. El SIF y Verifactu son de desarrolladores diferentes. Esta solución la quiero entregar antes de Navidad.
Seguimos,
Un Saludo
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
Carlos G.
FiveWin 24.02 + Harbour 3.2.0dev (r2403071241), BCC 7.7 Windows 10
- TOTOVIOTTI
- Posts: 429
- Joined: Fri Feb 05, 2010 11:30 am
- Location: San Francisco - Córdoba - Argentina
- Has thanked: 4 times
Re: Multihilo - Multithread (duda)
Hola Estimados...
una consulta porque no lo entiendo bien... a ver si me desburran...
Puedo usar un "thread" cuando inicio mi programa principal?
Ejemplo, hago la presentación de mi sistema y llego a menú principal,
mientras tanto, puedo ir haciendo un "thread" de una lectura de una tabla secundaria, y me guarde
esos datos en la memoria?
Espero se entienda lo que quiero hacer...
Muchas gracias!!
Roberto
una consulta porque no lo entiendo bien... a ver si me desburran...
Puedo usar un "thread" cuando inicio mi programa principal?
Ejemplo, hago la presentación de mi sistema y llego a menú principal,
mientras tanto, puedo ir haciendo un "thread" de una lectura de una tabla secundaria, y me guarde
esos datos en la memoria?
Espero se entienda lo que quiero hacer...
Muchas gracias!!
Roberto
- leandro
- Posts: 1719
- Joined: Wed Oct 26, 2005 2:49 pm
- Location: Colombia
- Has thanked: 11 times
- Been thanked: 3 times
- Contact:
Re: Multihilo - Multithread
Roberto buenas noches como estas?
Pues en ese caso yo usaria un servicio... es lo que se me ocurre de momento, creo que se adapta mejor a lo que quieres hacer. En estos días que me quede un tiempito voy a empezar a trabajar en montar un servicio similar a lo que necesitas hacer, apenas tenga algo de código lo publico.
Pues en ese caso yo usaria un servicio... es lo que se me ocurre de momento, creo que se adapta mejor a lo que quieres hacer. En estos días que me quede un tiempito voy a empezar a trabajar en montar un servicio similar a lo que necesitas hacer, apenas tenga algo de código lo publico.
Saludos
LEANDRO AREVALO
Bogotá (Colombia)
https://hymlyma.com
https://hymplus.com/
leandroalfonso111@gmail.com
leandroalfonso111@hotmail.com
[ Turbo Incremental Link64 6.98 Embarcadero 7.70 ] [ FiveWin 24.09 ] [ xHarbour 64 bits) ]
LEANDRO AREVALO
Bogotá (Colombia)
https://hymlyma.com
https://hymplus.com/
leandroalfonso111@gmail.com
leandroalfonso111@hotmail.com
[ Turbo Incremental Link64 6.98 Embarcadero 7.70 ] [ FiveWin 24.09 ] [ xHarbour 64 bits) ]
- TOTOVIOTTI
- Posts: 429
- Joined: Fri Feb 05, 2010 11:30 am
- Location: San Francisco - Córdoba - Argentina
- Has thanked: 4 times
Re: Multihilo - Multithread
Muchas gracias Leandro!!
Estaré atento a ver que publicas.
Yo lo hice funcionar de la siguiente manera:
hb_threadStart( HB_THREAD_INHERIT_PUBLIC, @MyFuncForThreads(),parametro1,parametro2,...)
Y luego para compilar reemplacé:
hbvm.lib x hbvmmt.lib
y
cw32.lib x cw32mt.lib
Sakudos!
Estaré atento a ver que publicas.
Yo lo hice funcionar de la siguiente manera:
hb_threadStart( HB_THREAD_INHERIT_PUBLIC, @MyFuncForThreads(),parametro1,parametro2,...)
Y luego para compilar reemplacé:
hbvm.lib x hbvmmt.lib
y
cw32.lib x cw32mt.lib
Sakudos!