委托的使用(转)
C# 从1.x 发展到目前的 4.5,委托的写法真是越来越简单精悍。如果您对这些委托的写法不是很清晰,本文可以帮助到您。
委托是一种安全封装方法的类型,可以将方法作为方法的参数。
委派方法的参数个数、顺序、类型及方法返回值类型必须跟定义的委托方法一样,但参数名称可以不同。
1、C# 定义一个完整委托:
delegate string SayMessage(string msg); static string SayHello(string Name) { return string.Format("Hello {0}", Name); } static void Main(string[] args) { SayMessage say = new SayMessage(SayHello); Console.WriteLine(say("委托")); Console.ReadKey(); }
输出结果:"Hello 委托"
2、C#2.0后出现了匿名方法,可以将委托方法省略掉,直接给委托传递一个匿名方法,当然也要去掉New这个动作。
delegate string SayMessage(string msg); static void Main(string[] args) { SayMessage say = delegate(string Name) { return string.Format("Hello {0}", Name); }; Console.WriteLine(say("匿名方法")); Console.ReadKey(); }
输出结果:"Hello 匿名方法"
3、 聪明的人们总是想使用更少的代码达到相同的效果。因此C#3.0 之后出现了 Lambda表达式、Action委托、Func 委托
(1) Lambda表达式:匿名方法的升级版,可以简化匿名方法的写法。写法 (形参列表)=>{ 表达式 OR 函数体 }
delegate string SayMessage(string msg); static void Main(string[] args) { SayMessage say = (Name) => { return string.Format("Hello {0}", Name); }; Console.WriteLine(say("Lambda")); Console.ReadKey(); }
输出结果:"Hello Lambda"
通过看上面的代码,能否将定义的委托 SayMessage 也去掉吗?当然可以,用 Func委托 或者 Action委托 就可以取代它!
(2)Func 委托:当我们封装一个具有返回值方法的时候就可以使用Func委托。
Func 委托一共有 15种重载,但总会有一个返回值,比如我们示例中用到的Func<T, TResult>委托就是其中之一。
Func<T, TResult>的作用就是 封装一个具有一个T类型参数并返回 TResult 类型值参数的方法。
如果封装方法没有有输入参数则直接使用Func<TResult> 委托。
static void Main(string[] args) { Func<string, string> say1 = delegate(string Name) { return string.Format("Hello {0}", Name); }; //和Lambda 结合 Func<string, string> say2 = (Name) => { return string.Format("Hello {0}", Name); }; Console.WriteLine(say1("Func 委托")); Console.WriteLine(say2("Func 委托")); Console.ReadKey(); }
输出结果:"Hello Func 委托"
(3)Action委托:当我们封装一个没有返回参数的方法时,就可以使用Action委托。
Action委托也有 15种重载,封装的方法可有有输入参数,但不会有返回参数。
比如下面示例代码中用到的Action<T>委托,其作用就是 封装一个具有T类型参数且无返回值参数 的方法。
如果封装方法没有输入参数则可以直接使用 Action 委托。
static void Main(string[] args) { Action<string> say1 = delegate(string Name) { Console.WriteLine(string.Format("Hello {0}", Name)); }; //和Lambda 结合 Action<string> say2 = (Name)=> { Console.WriteLine(string.Format("Hello {0}", Name)); }; say1("Action 委托"); say2("Action 委托"); Console.ReadKey(); }
输出结果:"Hello Action 委托"
转自:http://www.cnblogs.com/lxblog/archive/2013/02/27/2935089.html
[奔跑的人生] | [segmentfault] | [spring4all] | [csdn] | [掘金] | [OSChina] | [简书] | [知乎] | [51CTO]
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?