我必须继续运行24x7的方法。基本上 应用程序应该通过使用某个线程每秒处理40个数据。 我可以使用while或递归调用相同的方法。但在这两个过程中 cpu使用率过高几乎95-100%。我不能使用计时器,因为 然后处理线程无法正常工作。根据提供的解决方案 许多人说话时使用线程睡眠。但如果我使用线程睡眠 然后它在每次迭代中都会出现延迟。我正在使用c#4.0。
我的问题:有没有更好的解决方案来减少cpu的使用?
主要方法:
static void Main(string[] args)
{
while(true)
{
processData();
Thread.sleep(1000);
// here i use a 1 second sleep just for give a breath of CPU.
//But this one second sleep make me delay for enter data processing.
// I am looking for a better solution that no sleep time will use and CPU usages will getting low.
}
}
//Method should run always
static string processData()
{
{
// Open and close threads to process the data in every second.
}
// processData(); // it can be used for recursive method calling
}
答案 0 :(得分:7)
但如果我使用线程休眠,那么它会在每次迭代中得到延迟。我正在使用c#4.0。
您可以使用Thread.Sleep(0)
,表示:
应该挂起此线程以允许其他等待线程执行。
static void Main(string[] args)
{
while(true)
{
processData();
Thread.sleep(0);
}
}
这将允许线程放弃对其他线程的一些处理,防止它使用100%的CPU,但仍然允许它以接近全速运行。
请注意,使用任何延迟,虽然它会降低整体CPU使用率,但 会降低总吞吐量。最大化吞吐量的唯一方法是允许它不停旋转,这当然会使CPU使用率保持很高。
答案 1 :(得分:0)
static void Main(string[] args)
{
while(true)
{
var beginTime = DateTime.Now;
processData();
var duration = DateTime.Now.Subtract( beginTime );
// if you want to run 40 times per second,
// you need to spend 1000/40 = 25ms per iteration
var sleepDuration = (int)(25 - duration.TotalMilliseconds);
if( 0 < sleepDuration )
{
Thread.sleep(sleepDuration);
}
}
}
编辑:如另一个答案所示,如果您的Timer
方法是线程安全的,则可以使用processData()
类
答案 2 :(得分:0)
使用System.Threading.Timer,您可以告诉它何时下次执行,例如:
System.Threading.Timer myTimer = new System.Threading.Timer(~~~)
在myTimer回调中:
myTimer.Change(nextRunTime, newInterval);
这将在nextRunTime中运行下一个代码,间隔将变为newInterval。
有关“更改”方法的更多信息,请点击此处:
http://msdn.microsoft.com/en-us/library/7hs7492w.aspx
在System.Threading.Timer上:
http://msdn.microsoft.com/en-us/library/system.threading.timer.aspx
享受:)
如果我是冒昧的抱歉,我的印象是你不使用Timer的原因是因为总有一个固定的延迟,但是使用这种方法你可以在每次运行时调整延迟。
无论如何,如果您在定时器处理不正确的情况下遇到问题,您能分享那里到底出了什么问题吗?也许可以帮忙,最后使用Timer或类似的。
答案 3 :(得分:0)
uint loops = 0;
while (true)
{
if (Environment.ProcessorCount == 1 || (++loops % 100) == 0)
{
processData();
Thread.Sleep(1);
}
else
{
processData();
Thread.SpinWait(20);
}
}