委托的声明 public delegate void MyDelegate(string str); 同签名的方法调用。 个委托类型,从而在编译的时候对该类进行封装,对这一过程C#定义了专门的语法来处理这一过程。 C#中对委托定义了两个操作符 == 和 != 如上所述的两个不同类型的委托但是它们具有相同的签名和返回值时,只要满足上述条件的,即使它们类型不同,但比较的结果也是相同的。 委托的异常处理 当调用该委托的方法中发生了异常时,首先在调用该委托的方法中搜寻catch语句块。如果没有,则去该委托调用的方法中去寻找有没有catch语句块,这和调用方法发生异常的处 理是一样的。 当调用一个为null的委托即委托中列表中不存在调用方法时,将发生NullRefrenceException 委托的注意点: 后一个方法的返回值或是有out参数.如果该委托的参数为ref(引用类型),那么在招待第一个方法的时候如果对这个参数的值有所改变,那么这个改变将会影响到后面的方法调用. 委托的一个例子 using System; namespace ConsoleApplication1 // 创建一个委托实例,封装C类的静态方法M2 // 创建一个委托实例,封装C类的实例方法M3 // 从一个委托d3创建一个委托实例 // 组合两个委托 // 从组合委托中删除d3 MyDelegate d7 = new MyDelegate(C1.P1); MyDelegate d8 = new MyDelegate(new C2().P1); } // 声明一个委托MyDelegate public class C public static void M2(string str) public void M3(string str) public class C1 public class C2 事件委托 事件概述 事件就是当对象或类状态发生改变时,对象或类发出的信息或通知。发出信息的对象或类称为”事件源”,对事件进行处理的方法称为”接收者”,通常事件源在发出状态改变信息时,它 并不知道由哪个事件接收者来处理.这就需要一种管理机制来协调事件源和接收者,C++中通过函数指针来完成的.在C#中事件使用委托来为触发时将调用的方法提供类型安全的封装 1.声明一个委托 2.声明一个事件 3.引发一个事件 4.定义事件处理程序 5.订阅事件(将事件处理程序添加到事件的调用列表中) myText.Changed += EventHandler(MyText_OnChanged); 下面的一个小例子说明了怎样定义一个完整的事件机制: using System; namespace ConsoleApplication1 // 将事件处理程序添加到事件的调用列表中(即事件布线) // 对Change事件处理的程序 public class MyText // 定义事件的委托 // 定义一个事件 // 用以触发Change事件 // Text属性 自己的一些浅略的理解,还请大家多多批评指正!
注
1.委托的定义和方法的定义类似,只是在前面加了一个delegate,但委托不是方法,它是一种类型。是一种特殊的类型,看成是一种新的对象类型比较好理解。用于对与该委托有相
2.委托相当于C++中的函数指针,但它是类型安全的。
3.委托是从System.Delegate派生,但不能象定义常规类型一样直接从System.Delegate派生,对委托的声明只能通过上面的声明格式进行定义。关键字delegate通知编译器这是一
4.不能从一个委托类型进行派生,因为它也是默认sealed的
5.委托即可以对静态方法进行调用也可以对实例方法进行调用。
6.每个委托类型包含一个自己的调用列表,当组合一个委托或从一个委托中删除一个委托时都将产生个新的调用列表。
7.两个不同类型的委托即使它们有相同的签名和返回值,但还是两个不同类型的委托。但其实在使用中可看作是相同的。
委托的比较
在以下情况下两个委托是相等的:
1.当两个委托都同时为null的时候
2.当两个委托都不为null时,下列情况下是相等的。
a.当两个委托的各自的调用列表只含有一个入口点的时候
在下列情况下是相等的
(1) 调用同一对象的同一静态方法
(2) 调用同一对象的同一实例方法
b.当两个委托具有多个入口点时
在下列情况下是相等的
(1)只有当它们调用列表中的调用的方法按顺序都一一对应相同的对象及对象的同一方法的时候
当一个委托有多个入口点的时候,调用委托将依该委托的调用列表中的方法的顺序依次调用.这些方法共享一个参数集合,所以当委托有返回值的时候调用完这个委托后的返回值是最
using System.Collections.Generic;
using System.Text;
{
class Program
{
static void Main(string[] args)
{
// 创建一个委托实例,封装C类的静态方法M1
MyDelegate d1 = new MyDelegate(C.M1);
d1(“D1”); // M1
MyDelegate d2 = new MyDelegate(C.M2);
d2(“D2”); // M2
MyDelegate d3 = new MyDelegate(new C().M3);
d3(“D3”); // M3
MyDelegate d4 = new MyDelegate(d3);
d4(“D4”); // M3
MyDelegate d5 = d1 + d2;
d5 += d3;
d5(“D5”); // M1,M2,M3
MyDelegate d6 = d5 – d3;
d6(“D6”); // M1,M2
d6 -= d3; // 虽然d6调用列表中已经没有d3了,但这样只是不可能的移除没有错误发生
d6(“D6”); // M1,M2
d6 -= d6;
//d6(“D6”); 此时d6的调用列表为空,d6为null,所以引发System.NullReferenceException
d7(“D7”); // C1.P1
d8(“D8”); // C2.P1
}
public delegate void MyDelegate(string str);
{
public static void M1(string str)
{
Console.WriteLine(“From:C.M1: {0}”, str);
}
{
Console.WriteLine(“From:C.M2: {0}”, str);
}
{
Console.WriteLine(“From:C.M3: {0}”, str);
}
}
{
public static void P1(string str)
{
Console.WriteLine(“From:C1.P1: {0}”, str);
}
}
{
public void P1(string str)
{
Console.WriteLine(“From:C2.P1: {0}”, str);
}
}
}
事件的声明
public delegate void EventHandler(object sender, System.EventArgs e);
public event EventHandler Changed;
public OnChanged(EnventArgs e)
{
if ( Changed != null)
{
Changed(this,e);
}
}
public MyText_OnChanged(Object sender,EventArgs e)
{
…
}
using System.Collections.Generic;
using System.Text;
{
class Program
{
static void Main(string[] args)
{
MyText myText = new MyText();
myText.Changed += new MyText.ChangedEventHandler(myText_Changed);
string str = “”;
while (str != “quit”)
{
Console.WriteLine(“please enter a string:”);
str = Console.ReadLine();
myText.Text = str;
}
}
private static void myText_Changed(object sender, EventArgs e)
{
Console.WriteLine(“text has been changed :{0}\n” ,((MyText)sender).Text);
}
}
{
private string _text = “”;
public delegate void ChangedEventHandler(object sender, EventArgs e);
public event ChangedEventHandler Changed;
protected virtual void OnChanged(EventArgs e)
{
if (this.Changed != null)
this.Changed(this, e);
}
public string Text
{
get { return this._text; }
set
{
this._text = value;
// 文本改变时触发Change事件
this.OnChanged(new EventArgs());
}
}
}
}
对c#委托及事件委托的理解_c#应用
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 对c#委托及事件委托的理解_c#应用
相关推荐
-      利用c#远程存取access数据库_c#应用
-      c# 3.0新特性系列:隐含类型var_c#教程
-      c#动态生成树型结构的web程序设计_c#应用
-      论c#变得越来越臃肿是不可避免的_c#应用
-      用c#监控并显示cpu状态信息_c#应用
-      c#中实现vb中的createobject方法_c#应用
-      photoshop给花瓶打造彩绘效果_photoshop教程
-      使用c#创建sql server的存储过程_c#应用