C#2.0 新特性探究之委托与匿名委托
2005-10-17 11:02
239 查看
作者: Leafwiz
出处: CSDN
delegate经常被人用来与回调相比较,其实两者在某种程度上由很多共同点。不过delegate有很多更加强大的地方。
首先,delegate中可以注册任意多个回调,在一个delegate被调用的时候,已经注册的过程将会被逐个调用。
其次,delegate允许注册一个对象的方法,而不像C++中指可以使用静态方法或者全局方法作为函数指针,提供了更多的灵活性,同时也暗示我们,delegate中按照某种方式保存了object的很多信息。
在C#2.0的匿名delegate中,我们甚至可以访问当前匿名委托的上下文变量。接下来的文章中我们将会通过实际的例子,来看看强大的delegate。
首先,让我们看看在C#1.2中的一个典型的委托的写法。
现在我们可以写成这样:
或者将程序改写为:
比起1.2来,delegate的可读性更好,但是似乎没有本质的提高?慢着,让我们看看下面的例子。
注意,匿名函数中的内容!x + y的值被正确的输出了,而在1.2中,委托对于局部变量是没有除参数外的访问方式的。这样做有些什么好处呢?
让我们看一个更加复杂的例子:
这个例子中使用了系统线程池对于任务进行排队,适合于IO或者计算密集型的操作的时候。使用匿名委托最大的好处在于可以完整地克隆当前运行空间上下文的可用变量,虽然这可能从另一个层面上也增加了同步的复杂度,所谓有得必有失。
出处: CSDN
delegate经常被人用来与回调相比较,其实两者在某种程度上由很多共同点。不过delegate有很多更加强大的地方。
首先,delegate中可以注册任意多个回调,在一个delegate被调用的时候,已经注册的过程将会被逐个调用。
其次,delegate允许注册一个对象的方法,而不像C++中指可以使用静态方法或者全局方法作为函数指针,提供了更多的灵活性,同时也暗示我们,delegate中按照某种方式保存了object的很多信息。
在C#2.0的匿名delegate中,我们甚至可以访问当前匿名委托的上下文变量。接下来的文章中我们将会通过实际的例子,来看看强大的delegate。
首先,让我们看看在C#1.2中的一个典型的委托的写法。
public delegate void TheEvent(int a); public void test() { TheEvent testdel1 = new TheEvent(del1); testdel1(12); } public void del1(int x) { Console.WriteLine("output x : {0}", x); } |
public void test() { TheEvent testdel1 = del1; testdel1(12); } |
delegate void TheEvent2(int a); public void test2() { int a = 12; TheEvent ev2 = delegate(ref int x) { Console.WriteLine("output x : {0}", x); }; ev2( ref a); } |
public static void test3() { int a = 12; int y = 32; TheEvent ev2 = delegate(ref int x) { Console.WriteLine("output x + y : {0}", x + y); }; ev2( ref a); } |
让我们看一个更加复杂的例子:
public static void test4() { int a = 12; int y = 32; TheEvent ev2 = delegate(ref int x) { Console.WriteLine("output x + y : {0}", x + y); Thread.Sleep(100); }; //ev2(ref a); IAsyncResult ar = ev2.BeginInvoke(ref a, delegate(IAsyncResult ar2) {Console.Write("Operation finished: {0} on thread ID:{1}, is pool: {2}",ar2.IsCompleted,Thread.CurrentThread.GetHashCode(), Thread.CurrentThread.IsThreadPoolThread);} , null); Console.WriteLine("do some other calculations while counter thread is working"); Console.Write("work status : {0} Main Thread ID:{1}, is pool: {2}", ar.IsCompleted, Thread.CurrentThread.GetHashCode(), Thread.CurrentThread.IsThreadPoolThread); Thread.Sleep(500); ev2.EndInvoke(ref a, ar); } |
相关文章推荐
- C#2.0 新特性探究(二) 委托与匿名委托
- C#2.0 新特性探究之委托与匿名委托
- C#2.0 新特性探究(二) 委托与匿名委托
- C#2.0新特性探究之模拟泛型和内置算法
- C#2.0新特性探究之模拟泛型和内置算法
- C#2.0新特性探究之模拟泛型和内置算法
- 第1节 C#2.0新特性之五:非对称访问器可访问性
- C#2.0新特性(早期学习笔记)
- C# DotNet 2.0及3.0 新特性
- C#2.0新特性-泛型
- C# 2.0 新特性
- 实例 C#3.0与C#2.0相比之新特性(五) 分部方法 partial Method
- 学习C#2.0新特性:泛型!
- 对C#2.0新特性的理解
- C#学习笔记(三)—–C#高级特性中的委托与事件:关于事件
- 为什么在VS2010中编写.net 2.0程序可以调用C#2.0以上版本特性?
- C#2.0的新特性
- C#2.0新特性 - 友元程序集(Friend Assemblies)
- 分析 C# 2.0 新特性 -- 空类型(Nullable Types)
- 【第一章】C#的进化史——C#1.0,2.0,3.0区别比较(二)——C#2.0,3.0 简化排序的特性