C# Denegation.doc_第1页
C# Denegation.doc_第2页
C# Denegation.doc_第3页
C# Denegation.doc_第4页
C# Denegation.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

专题:c# Denegation1本质:没有类体的类修饰词+关键词denegation+返回类型+代理名(参数类型 参数); Public denegation void A(string str);2、代码示例网址:/code-snippet/4836/C-weituo-delegate-usage-fanliusing System;using System.Collections.Generic;using System.Text;namespace Delegate /委托简单说就是可以让方法作为变量进行传递. /定义委托,它定义了可以代表的方法的类型 public delegate void MyDelegate(string name); class Program /定义两个和委托相同参数的相同返回值的方法. 要和委托绑定的好像只能是静态方法.因为不是静态方法IDE会报错. public static void ShowMessage(string Message) Console.WriteLine(Hello + Message); public static void SHowMessage(string Message) / 在C#中是区分大小写的,所以这个方法和上面那个不是一样的. Console.WriteLine(你好 + Message); static void Main() /定义一个委托变量. 然后绑定方法. MyDelegate My = new MyDelegate(ShowMessage); /现在可以通过这个委托变量来使用方法了. My( Tony); /这里会输出Hello Tony. 疑问来了. 我们为什么不直接使用方法呢? 还定义一个委托变量干嘛? 多写了几行代码. / 其实委托的用处不是在这里. 我们可以试试这样. / 委托链, 一个委托变量绑定多个方法. My += SHowMessage; /输出看看 My(Tony); /输出结果将是 HelloTony and 你好Tony. / 分割线, 在方法中传递方法.用方法做参数/ /定义一个方法. public static void input(string name, MyDelegate Message) /这里面的Message就是委托变量了. 你可以将一个方法传递进去. Message(name); /使用方法来作为参数./ input(Tony , ShowMessage); input(Tony,SHowMessage); 3、代码示例:代码出处:/akwwl/p/3232679.htmlC#委托的介绍(delegate、Action、Func、predicate)委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递。事件是一种特殊的委托。1.委托的声明(1). delegate delegate我们常用到的一种声明Delegate至少0个参数,至多32个参数,可以无返回值,也可以指定返回值类型。 例:publicdelegateintMethodtDelegate(intx,inty);表示有两个参数,并返回int型。(2). Action Action是无返回值的泛型委托。 Action 表示无参,无返回值的委托 Action 表示有传入参数int,string无返回值的委托Action 表示有传入参数int,string,bool无返回值的委托 Action 表示有传入4个int型参数,无返回值的委托 Action至少0个参数,至多16个参数,无返回值。 例: public void Test(Action action,T p) action(p); (3). Func Func是有返回值的泛型委托 Func 表示无参,返回值为int的委托 Func 表示传入参数为object, string 返回值为int的委托 Func 表示传入参数为object, string 返回值为int的委托 Func 表示传入参数为T1,T2,T3(泛型)返回值为int的委托 Func至少0个参数,至多16个参数,根据返回值泛型返回。必须有返回值,不可void 例: public int Test(Funcfunc,T1 a,T2 b) return func(a, b); (4) .predicate predicate 是返回bool型的泛型委托 predicate 表示传入参数为int 返回bool的委托 Predicate有且只有一个参数,返回值固定为bool 例:publicdelegateboolPredicate (T obj)2.委托的使用(1).Delegate的使用 public delegate int MethodDelegate(int x, int y); private static MethodDelegate method; static void Main(string args) method = new MethodDelegate(Add); Console.WriteLine(method(10,20); Console.ReadKey(); private static int Add(int x, int y) return x + y; (2).Action的使用 static void Main(string args) Test(Action,Hello World!); Test(Action, 1000); Test(p = Console.WriteLine(0, p); , Hello World);/使用Lambda表达式定义委托 Console.ReadKey(); public static void Test(Action action, T p) action(p); private static void Action(string s) Console.WriteLine(s); private static void Action(int s) Console.WriteLine(s); 可以使用 Action 委托以参数形式传递方法,而不用显式声明自定义的委托。 封装的方法必须与此委托定义的方法签名相对应。 也就是说,封装的方法必须具有四个均通过值传递给它的参数,并且不能返回值。 (在 C# 中,该方法必须返回 void)通常,这种方法用于执行某个操作。(3).Func的使用 static void Main(string args) Console.WriteLine(Test(Fun,100,200); Console.ReadKey(); public static int Test(Func func, T1 a, T2 b) return func(a, b); private static int Fun(int a, int b) return a + b; (4).predicate的使用泛型委托:表示定义一组条件并确定指定对象是否符合这些条件的方法。此委托由 Array 和 List 类的几种方法使用,用于在集合中搜索元素。 static void Main(string args) Point points = new Point(100, 200), new Point(150, 250), new Point(250, 375), new Point(275, 395), new Point(295, 450) ; Point first = Array.Find(points, ProductGT10); Console.WriteLine(Found: X = 0, Y = 1, first.X, first.Y); Console.ReadKey(); private static bool ProductGT10(Point p) if (p.X * p.Y 100000) return true; else return false; 使用带有 Array.Find 方法的 Predicate 委托搜索 Point 结构的数组。如果 X 和 Y 字段的乘积大于 100,000,此委托表示的方法 ProductGT10 将返回 true。Find 方法为数组的每个元素调用此委托,在符合测试条件的第一个点处停止。3.委托的清空(1).在类中申明清空委托方法,依次循环去除委托引用。 方法如下: public MethodDelegate OnDelegate; public void ClearDelegate() while (this.OnDelegate != null) this.OnDelegate -= this.OnDelegate; (2).如果在类中没有申明清空委托的方法,我们可以利用GetInvocationList查询出委托引用,然后进行去除。方法如下: public MethodDelegate OnDelegate; static void Main(string args) Program test = new Program(); if (test.OnDelegate != null) System.Delegate dels = test.OnDelegate.GetInvocationList(); for (int i = 0; i dels.Length; i+) test.OnDelegate -= delsi as MethodDelegate; 4.委托的特点委托类似于

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论