博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
匿名方法
阅读量:6980 次
发布时间:2019-06-27

本文共 2285 字,大约阅读时间需要 7 分钟。

匿名方法(C# 编程指南)

Visual Studio 2015
 
 

 

在 2.0 之前的 C# 版本中,声明的唯一方法是使用。  C# 2.0 引入了匿名方法,而在 C# 3.0 及更高版本中,Lambda 表达式取代了匿名方法,作为编写内联代码的首选方式。  不过,本主题中有关匿名方法的信息同样也适用于 Lambda 表达式。  有一种情况下,匿名方法提供了 Lambda 表达式中所没有的功能。  您可使用匿名方法来忽略参数列表。  这意味着匿名方法可转换为具有各种签名的委托。  这对于 Lambda 表达式来说是不可能的。  有关 lambda 表达式的更多特定信息,请参见 。  

要将代码块传递为委托参数,创建匿名方法则是唯一的方法。  这里是两个示例:  

C#
 
// Create a handler for a click event.button1.Click += delegate(System.Object o, System.EventArgs e)                   { System.Windows.Forms.MessageBox.Show("Click!"); };
C#
 
// Create a delegate.delegate void Del(int x);// Instantiate the delegate using an anonymous method.Del d = delegate(int k) { /* ... */ };

通过使用匿名方法,由于您不必创建单独的方法,因此减少了实例化委托所需的编码系统开销。

例如,如果创建方法所需的系统开销是不必要的,则指定代码块(而不是委托)可能非常有用。  启动新线程即是一个很好的示例。  无需为委托创建更多方法,线程类即可创建一个线程并且包含该线程执行的代码。  

C#
 
void StartThread(){    System.Threading.Thread t1 = new System.Threading.Thread      (delegate()            {                System.Console.Write("Hello, ");                System.Console.WriteLine("World!");            });    t1.Start();}

匿名方法的参数的范围是“匿名方法块”。

如果目标在块外部,那么,在匿名方法块内使用跳转语句(如 、 或 )是错误的。  如果目标在块内部,在匿名方法块外部使用跳转语句(如 gotobreakcontinue)也是错误的。  

如果局部变量和参数的范围包含匿名方法声明,则该局部变量和参数称为该匿名方法的“外部”变量。  例如,下面代码段中的 n 即是一个外部变量:  

C#
 
int n = 0;Del d = delegate() { System.Console.WriteLine("Copy #:{0}", ++n); };

外部变量的引用n被认为是捕获在创建委托时。  与本地变量不同,捕获的变量的生存期内扩展,直到引用该匿名方法委托被垃圾回收。  

匿名方法不能访问外部范围的 或 参数。

在“匿名方法块”中不能访问任何不安全代码。

在 运算符的左侧不允许使用匿名方法。

示例

下面的示例演示实例化委托的两种方法:

  • 使委托与匿名方法关联。

  • 使委托与命名方法 (DoWork) 关联。

两种方法都会在调用委托时显示一条消息。

C#
 
// Declare a delegate.delegate void Printer(string s);class TestClass{    static void Main() { // Instantiate the delegate type using an anonymous method. Printer p = delegate(string j) { System.Console.WriteLine(j); }; // Results from the anonymous delegate call. p("The delegate using the anonymous method is called."); // The delegate instantiation using a named method "DoWork". p = new Printer(TestClass.DoWork); // Results from the old style delegate call. p("The delegate using the named method is called."); } // The method associated with the named delegate. static void DoWork(string k) { System.Console.WriteLine(k); } } /* Output: The delegate using the anonymous method is called. The delegate using the named method is called. */

转载于:https://www.cnblogs.com/dingfangbo/p/5740304.html

你可能感兴趣的文章
使用maven的profile切换项目各环境的参数
查看>>
XML基础知识
查看>>
Sharepoint学习笔记—习题系列--70-576习题解析 -(Q141-Q143)
查看>>
sudo配置文件/etc/sudoers格式
查看>>
span设置padding无效
查看>>
RGB、HSB、HSL 互相转换算法
查看>>
【转】外企高管们的“中年危机”
查看>>
HeapAlloc 和 GlobalAlloc 以及 VirtualAlloc 三者之间的关系(转)
查看>>
你一定不知道IDE里的Tomcat是怎么工作的
查看>>
Java面试通关要点汇总集
查看>>
从源码角度理解Handler、Looper、MessageQueue之间关系
查看>>
Bitmap 比你想的更费内存 | 吊打 OOM
查看>>
为你揭秘小程序音视频背后的故事......
查看>>
自定义侧边快速索引栏
查看>>
一种自动化检测 Flash 中 XSS 方法的探讨
查看>>
基于环信sdk实现简单即时聊天
查看>>
Java基础-Synchronized原理
查看>>
大道至简,阿里巴巴敏捷教练的电子看板诞生记
查看>>
华山论剑之浅谈iOS的生产线 工厂模式
查看>>
浅谈javascript异步发展历程
查看>>