本文整理汇总了C#中Microsoft.WindowsAzure.Storage.Queue.CloudQueue.FetchAttributesAsync方法的典型用法代码示例。如果您正苦于以下问题:C# CloudQueue.FetchAttributesAsync方法的具体用法?C# CloudQueue.FetchAttributesAsync怎么用?C# CloudQueue.FetchAttributesAsync使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Microsoft.WindowsAzure.Storage.Queue.CloudQueue
的用法示例。
在下文中一共展示了CloudQueue.FetchAttributesAsync方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: StartAsync
protected override async Task StartAsync()
{
InfoLogging(string.Format("{0} - Processing", QueueName));
_queue = await _clientFactory.CreateStorageQueueClientAsync(QueueName).ConfigureAwait(false);
var stopWatch = new Stopwatch();
while (!Token.IsCancellationRequested)
{
await _queue.FetchAttributesAsync().ConfigureAwait(false);
if (_queue.ApproximateMessageCount.GetValueOrDefault() <= 0)
{
await Task.Delay(LoopWaitTime).ConfigureAwait(false);
continue;
}
var messages = await _queue
.GetMessagesAsync(MessageCount, TimeSpan.FromSeconds(10), null, null, Token)
.ConfigureAwait(false);
var cloudQueueMessages = messages as IList<CloudQueueMessage> ?? messages.ToList();
if (!cloudQueueMessages.Any()) continue;
var correlationId = Guid.NewGuid().ToString();
DebugLogging(string.Format("{0} - Received {1} new messages", QueueName, cloudQueueMessages.Count),
correlationId);
stopWatch.Restart();
await Do(cloudQueueMessages).ConfigureAwait(false);
stopWatch.Stop();
var timeSpan = stopWatch.Elapsed;
DebugLogging(string.Format("{0} - Processed messages", QueueName), correlationId,
timeSpan.TotalSeconds);
}
}