44

听说异步执行有四种模式。

异步委托执行有四种模式:轮询、等待完成、完成通知和“一劳永逸”

当我有以下代码时:

class AsynchronousDemo
{
    public static int numberofFeets = 0;
    public delegate long StatisticalData();

    static void Main()
    {
        StatisticalData data = ClimbSmallHill;
        IAsyncResult ar = data.BeginInvoke(null, null);
        while (!ar.IsCompleted)
        {
            Console.WriteLine("...Climbing yet to be completed.....");
            Thread.Sleep(200);

        }
        Console.WriteLine("..Climbing is completed...");
        Console.WriteLine("... Time Taken for  climbing ....{0}", 
        data.EndInvoke(ar).ToString()+"..Seconds");
        Console.ReadKey(true);

    }


    static long ClimbSmallHill()
    {
        var sw = Stopwatch.StartNew();
        while (numberofFeets <= 10000)
        {
            numberofFeets = numberofFeets + 100;
            Thread.Sleep(10);
        }
        sw.Stop();
        return sw.ElapsedMilliseconds;
    }
}

1)上述代码实现的模式是什么?

2)你能解释一下代码吗,我怎样才能实现其余的..?

4

3 回答 3

99

你所拥有的是轮询模式。在这种模式下,你不断地问“我们到了吗?” while循环正在执行阻塞。这Thread.Sleep可以防止进程占用 CPU 周期。


等待完成是“我会打电话给你”的方法。

IAsyncResult ar = data.BeginInvoke(null, null);
//wait until processing is done with WaitOne
//you can do other actions before this if needed
ar.AsyncWaitHandle.WaitOne(); 
Console.WriteLine("..Climbing is completed...");

因此,一旦WaitOne被调用,您就会阻塞,直到攀爬完成。您可以在阻止之前执行其他任务。


使用完成通知,您是在说“你打电话给我,我不会打电话给你”。

IAsyncResult ar = data.BeginInvoke(Callback, null);

//Automatically gets called after climbing is complete because we specified this
//in the call to BeginInvoke
public static void Callback(IAsyncResult result) {
    Console.WriteLine("..Climbing is completed...");
}

这里没有阻塞,因为Callback会收到通知。


火和忘记将是

data.BeginInvoke(null, null);
//don't care about result

这里也没有阻塞,因为您不在乎攀登何时完成。顾名思义,你忘了它。你是在说“不要打电话给我,我不会打电话给你,但是,不要打电话给我。”

于 2009-11-23T18:20:49.760 回答
4
while (!ar.IsCompleted)
{
    Console.WriteLine("...Climbing yet to be completed.....");
    Thread.Sleep(200);
}

这是经典的民意调查。- 检查,睡觉,再次检查,

于 2009-11-23T18:20:22.977 回答
2

此代码是轮询:

while (!ar.IsCompleted)

这是关键,你不断检查它是否完成。

这段代码并不真正支持所有四个,但有些代码支持。

Process fileProcess = new Process();
// Fill the start info
bool started = fileProcess.Start();

“开始”方法是异步的。它产生了一个新的过程。

我们可以使用此代码执行您要求的每种方式:

// Fire and forget
// We don't do anything, because we've started the process, and we don't care about it

// Completion Notification
fileProcess.Exited += new EventHandler(fileProcess_Exited);

// Polling
while (fileProcess.HasExited)
{

}

// Wait for completion
fileProcess.WaitForExit();
于 2009-11-23T18:19:26.317 回答