Compartilhar via


Como: Enviar uma mensagem em intervalos regulares

Este exemplo mostra como usar o Concurrency::timer classe para enviar uma mensagem em intervalos regulares.

Exemplo

O exemplo a seguir utiliza um timer o objeto para relatar o progresso durante uma operação demorada. Este exemplo vincula a timer o objeto para um Concurrency::call objeto. O call objeto imprime um indicador de progresso para o console em um intervalo regular. O Concurrency::timer::start método executa o timer em um contexto separado. O perform_lengthy_operation chamadas de função do Concurrency::wait a função no contexto do 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 produz a saída de exemplo a seguir:

Performing a lengthy operation..........done.

Compilando o código

Copie o código de exemplo e colá-lo em um Visual Studio do projeto, ou colá-lo em um arquivo que é chamado progress.cpp de relatório e, em seguida, execute o seguinte comando um Visual Studio 2010 janela do Prompt de comando.

cl.exe /EHsc report-progress.cpp

Consulte também

Referência

Timer de classe

Conceitos

Biblioteca de agentes assíncronos

Blocos de mensagens assíncronas

Funções de transmissão de mensagens