Saltar para o conteúdo principal
Versão: 20 R7

New signal

New signal { ( description : Text ) } : 4D.Signal

ParâmetroTipoDescrição
descriptionTextDescrição para o sinal
Resultado4D. SignalObjeto nativo encapsulando o sinal
História
ReleaseMudanças
17 R4Adicionado

Descrição

The New signal command creates a 4D.Signal object.

Um sinal é um objeto partilhado que pode ser passado como parâmetro de um worker ou processo para outro worker ou processo, de forma que:

  • o worker/processo chamado pode atualizar o objeto sinal depois de um processamento especifico ter terminado
  • o worker/processo chamado pode parar sua execução e esperar até que o sinal seja atualizado, sem consumir qualquer recurso de CPU.

Optionally, in the description parameter you can pass a custom text describing the signal. Esse texto pode também ser definido depois da criação do sinal.

Since the signal object is a shared object, it can also be used to maintain user properties, including the .description property, by calling the Use...End use structure.

Valor retornado

Um novo objeto 4D.Signal.

Exemplo

Este é um exemplo típico de um worker que fixa um sinal:

 var $signal : 4D.Signal
$signal:=New signal("This is my first signal")

CALL WORKER("myworker";"doSomething";$signal)
$signaled:=$signal.wait(1) //wait for 1 second max

If($signaled)
ALERT("myworker finished the work. Result: "+$signal.myresult)
Else
ALERT("myworker has not finished in less than 1s")
End if

O método doSomething poderia ser como:

 #DECLARE ($signal : 4D.Signal)
//any processing
//...
Use($signal)
$signal.myresult:=$processingResult //return the result
End use
$signal.trigger() // The work is finished

Propriedades

Command number1641
Thread safe✓