Como enviar uma mensagem em um intervalo regular
Este exemplo mostra como usar a classe de concurrency::timer para enviar uma mensagem em um intervalo normal.
Exemplo
O exemplo a seguir usa um objeto de timer ao progresso de relatório durante uma operação demorada. Este exemplo vincula o objeto de timer a um objeto de concurrency::call . O objeto de call imprime um indicador de progresso no console em um intervalo normal. O método de concurrency::timer::start executa o timer em um contexto separado. As chamadas de função de perform_lengthy_operation a função de concurrency::wait no contexto principal para simular uma operação demorada.
// report-progress.cpp
// compile with: /EHsc
#include <agents.h>
#include <iostream>
using namespace concurrency;
using namespace std;
// Simulates a lengthy operation.
void perform_lengthy_operation()
{
// Yield the current context for one second.
wait(1000);
}
int wmain()
{
// Create a call object that prints a single character to the console.
call<wchar_t> report_progress([](wchar_t c) {
wcout << c;
});
// Create a timer object that sends the dot character to the
// call object every 100 milliseconds.
timer<wchar_t> progress_timer(100, L'.', &report_progress, true);
wcout << L"Performing a lengthy operation";
// Start the timer on a separate context.
progress_timer.start();
// Perform a lengthy operation on the main context.
perform_lengthy_operation();
// Stop the timer and print a message.
progress_timer.stop();
wcout << L"done.";
}
Este exemplo gerencia a seguinte saída de exemplo:
Compilando o código
Copie o código de exemplo e cole-o em um projeto do Visual Studio, ou cole-o em um arquivo chamado report-progress.cpp e execute o comando a seguir em uma janela de prompt de comando do Visual Studio.
cl.exe /EHsc report-progress.cpp
Consulte também
Referência
Conceitos
Biblioteca de Agentes Assíncronos