我正在运行此代码,它使用了相当数量的CPU,即使它在大多数时间都没有做任何事情.
while (this.IsListening) { while (this.RecievedMessageBuffer.Count > 0) { lock (this.RecievedMessageBuffer) { this.RecievedMessageBuffer[0].Reconstruct(); this.RecievedMessageBuffer[0].HandleMessage(messageHandler); this.RecievedMessageBuffer.RemoveAt(0); } } }
在满足条件之前阻止的最佳方法是什么?
解决方法
假设您使用的是.NET 4,我建议将RecievedMessageBuffer切换为
BlockingCollection.当您将消息放入其中时,请将其称为
Add方法.如果要检索邮件,请将其命名为
Take或
TryTake方法. Take将阻止读取线程,直到有消息可用,而不像原始示例那样刻录CPU.
// Somewhere else BlockingCollection<SomethingLikeAMessage> RecievedMessageBuffer = new BlockingCollection<SomethingLikeAMessage>(); // Something like this where your example was while (this.IsListening) { SomethingLikeAMessage message; if (RecievedMessageBuffer.TryTake(out message,5000); { message.Reconstruct(); message.HandleMessage(messageHandler); } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。