C# winform 怎样用 委托
什么是委托
首先要知道什么是委托,用最通俗易懂的话来讲,你就可以把委托看成是用来执行方法(函数)的一个东西。
如何使用委托
在使用委托的时候,你可以像对待一个类一样对待它。即先声明,再实例化。只是有点不同,类在实例化之后叫对象或实例,但委托在实例化后仍叫委托。
声明,如:
namespace Vczx.ProCSharp.Exc
{
delegate double MathsOp( double x );
//class defination here
}
这就声明了一个委托,意义:任何一个返回值为double,且只有一个形参为double的函数,都可以用这个委托来调用。
注意:委托的声明位置在namespace里面,类的外面。其实,委托的声明也可以在类的里面,甚至是任何一个可以声明类的地方。
实例化:
首先我们要先有一个满足委托声明的方法,假设一个返回一个数的2倍的方法:
class MathsOperations
{
public static double MultiplyBy2( double value )
{
return value * 2;
}
}
有了这样一个方法,我们就可以实例化一个委托了:
MathsOp operation = new MathsOp( MathsOperations.MultiplyBy2 );
在实例化一个委托时,要给它一个参数,这个参数就是委托执行的方法,它可以是静态方法,也可以是实例方法(这一点有别于函数指针,函数指针只能调用静态方法),如:
MathsOp operation = new MathsOp( new Class1().Method1 );
在实例化完一个委托之后,就可以用这个委托来调用方法了:
double result = operation( 1.23 );
c#中委托的作用是什么?
使用委托的作用:使程序员可以将方法引用封装在委托对象内。然后可以将该委托对象传递给可调用所引用方法的代码,而不必在编译时知道将调用哪个方法。与C或C++中的函数指针不同,委托是面向对象,而且是类型安全的。委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递,这种将方法动态地赋给参数的做法,可以避免在程序中大量使用If-Else(Switch)语句,同时使得程序具有更好的可扩展性。委托和事件在.NET Framework中的应用非常广泛,然而,较好地理解委托和事件对很多接触C#时间不长的人来说并不容易。扩展资料:委托的本质:在C#中使用delegate关键字定义委托,然后使用我们熟悉的函数调用的语法来调用委托,如上述例子中的cb(“skynet”,23)。在这简单的表象背后,.NET编译器可以知道定义CallBack委托时,编译器为我们做了如下工作,实际上定义任何委托编译器都会做如下工作:声明一个类,对应上图中的.class nested public auto ansi sealed。该类扩展自System.MulticastDelegate,对应上图中的extends [mscorlib]System.MulticastDelegate。该类包含一个构造器,对应上图中的.ctor: void(object ,native int)。该类包含三个方法,分别是BeginInvoke、EndInvoke、Invoke。参考资料来源:百度百科-委托 (C#类)参考资料来源:百度百科-c#委托
c#中委托怎么用?
委托主要用于.NET Framework中的事件处理程序和回调函数,它是事件的基础。
委托的作用类似于c++中函数指针的作用。不同的是,委托实例独立于它所封装的方法的类,并且方法类型与委托的类型是兼容的。函数指针只能引用静态函数,而委托可以应用静态和实例方法。
所有委托都是继承自System.Delegate类,并且有一个调用列表。调用委托时所执行的方法都被存放在这样的一个连接列表中。
使用delegate关键字可以声明一个委托。通过将委托与命名方法或匿名方法关联,可以对委托进行实例化。为了与命名方法一起使用,委托必须用具有可接受签名的方法进行实例化。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleApplication1
{
//声明一个委托
delegate int Mydelegate();
class Program
{
static void Main(string[] args)
{
test p = new test();
//将委托指向非静态方法
Mydelegate m = new Mydelegate(p.InstanceMethod);
//调用非静态方法
m();
//将委托指向静态方法
m = new Mydelegate(test.StaticMethod);
//调用静态方法
m();
Console.Read();
}
}
public class test
{
public int InstanceMethod()
{
Console.WriteLine("正在调用非静态方法InstanceMethod()....");
return 0;
}
static public int StaticMethod()
{
Console.WriteLine("正在调用静态方法StaticMethod()。。。。");
return 0;
}
}
}