1.Invoke
delegate void test(); static void Main(string[] args) { test ts = new test(TestDelegate); ts.Invoke(); Console.WriteLine("hello"); } internal static void TestDelegate() { Thread.Sleep(1000); }
在主线程中会出现 1 秒钟的阻塞,因为 Invoke 是同步的,而不是创建新线程。
2.BeginInvoke
delegate string test(); static void Main(string[] args) { test ts = new test(TestDelegate); IAsyncResult result = ts.BeginInvoke(null, null); string resultstr = ts.EndInvoke(result); Console.WriteLine(resultstr); } internal static string TestDelegate() { Thread.Sleep(1000); return "hello" }
BeginInvoke 会在新线程中执行,并且不会对主线程产生租塞,同时它可以获取自己的返回值,使用EndInvoke实现。
Delegate.BeginInvoke 方法是从 ThreadPool 取出一个线程来执行这个方法,以获得异步执行效果的。也就是说,如果采用这种方式提交多个异步委托,那么这些调用的顺序无法得到保证。而且由于是使用线程池里面的线程来完成任务,使用频繁,会对系统的性能造成影响。