【C#】C#委托学习

摘要:
尽管我一直在做。NET近两年,基础不是很好。今天我阅读了委托的知识并记录了下来。因此,在引入委托之后,程序员可以将方法的引用封装在委托对象中,然后将委托对象传递给要引用的方法*/PrivateevoidWriteText{stringdata=textBox3。文本对于{//使用委托-通过不同委托运行不同的writtextbox方法;//间歇性延迟DateTimenow=DateTime.Now;while{}}//添加字符privatevoidWriteTextBox1{textBox1。附录文本;}//添加字符privatevoidWriteTextBox2{textBox2。附录文本;}}表格1.csb。渲染:2。委托链实际上是一个委托,它只包含多个委托。

虽然做.NET这行也快2年了,但基础不太好啊,今天看了下委托方面的知识,记录下。

1.委托

总的来说,委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递,这种将方法动态地赋给参数的做法,可以避免在程序中大量使用If-Else(Switch)语句,同时使得程序具有更好的可扩展性。
所以,引入委托后,编程人员可以把方法的引用封装在委托对象中,然后把委托对象传递给需要引用方法。
调用委托和调用方法的方式是一模一样的,代码如下:

a.代码:

【C#】C#委托学习第1张【C#】C#委托学习第2张
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace WForms
{
    public partial class Form1 : Form
    {
        //定义委托
        private delegate void WriteTextBox(char ch);
        //声明委托
        private WriteTextBox writeTextBox;
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            if (checkBox1.Checked == true)
            {
                textBox1.Clear();
                textBox1.Refresh();
                // 实例化委托- 方法WriteTextBox1
                writeTextBox = new WriteTextBox(WriteTextBox1);
                // 委托作为参数,在方法WriteText通过委托运行WriteTextBox1方法
                WriteText(writeTextBox);

                textBox3.Focus();
                textBox3.SelectAll();
            }
            if (checkBox2.Checked == true)
            {
                textBox2.Clear();
                textBox2.Refresh();
                // 实例化委托 - 方法WriteTextBox2作为参数
                writeTextBox = new WriteTextBox(WriteTextBox2);
                // 委托作为参数,在方法WriteText通过委托运行WriteTextBox2方法
                WriteText(writeTextBox);
                textBox3.Focus();
                textBox3.SelectAll();
            }
        }

        /**
         *我们通过WriteText方法来向文本区写入内容,
         *它所执行的只是抽象的”写文本“操作,至于究竟向哪个文本框写入文字,
         *对于编写WriteText方法的程序来说是不知道,委托writeTextBox就像一个接口一样,
         *屏蔽了操作对象的差别(方法到底是想向文本区1写入文本还是像文本区2写入文本,
         *现在我方法里面不需要去关心,
         *我只需要集中在实现”书写文本”这个操作,而不必纠结操作对象的选择)。
         */
        private void WriteText(WriteTextBox writetextbox)
        {
            string data = textBox3.Text;
            for (int i = 0; i < data.Length; i++)
            {
                // 使用委托 - 通过委托的不同运行不同的方法
                writetextbox(data[i]);
                //间歇延时
                DateTime now = DateTime.Now;
                while (now.AddSeconds(1) > DateTime.Now) { }
            }
        }
        //向文本区1添加字符
        private void WriteTextBox1(char ch)
        {
            textBox1.AppendText(ch.ToString());
        }
        //向文本区2添加字符
        private void WriteTextBox2(char ch)
        {
            textBox2.AppendText(ch.ToString());
        }
    }
}
Form1.cs

b.效果图:

【C#】C#委托学习第3张

2.委托链

其实委托链就是一个委托,只是包含了多个委托而已。看完下面代码,应该可以很明白。

a.代码:

【C#】C#委托学习第1张【C#】C#委托学习第5张
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication1
{
    class Program
    {
        // 声明一个委托类型,它的实例引用一个方法,该方法返回一个string类型
        public delegate string DelegateTest();
        public static void Main(string[] args)
        {
            // 用静态方法来实例化委托
            DelegateTest dtstatic = new DelegateTest(Program.method1);

            // 用实例方法来实例化委托
            DelegateTest dtinstance = new DelegateTest(new Program().method2);
            DelegateTest dtinstance2 = new DelegateTest(new Program().method3);
            // 定义一个委托链对象,一开始初始化为null,就是不代表任何方法(我就是我,我不代表任何人)
            DelegateTest delegatechain = null;
            delegatechain += dtstatic;
            delegatechain += dtinstance;
            delegatechain += dtinstance2;
            // Environment.NewLine - 换行符
            Console.WriteLine(Environment.NewLine + dtstatic() + Environment.NewLine);// 隐式调用委托
            Console.WriteLine(dtstatic.Invoke() + Environment.NewLine);// 显式调用委托
            Console.WriteLine(Environment.NewLine + Test(delegatechain));//输出字符串
            Console.Read();

        }
        private static string method1()
        {
            return "这是静态方法1";
        }

        private string method2()
        {
            throw new Exception("抛出了一个异常");
        }

        private string method3()
        {
            return "这是实例方法3";
        }
        // 测试调用委托的方法
        private static string Test(DelegateTest chain)
        {
            if (chain == null)
            {
                return null;
            }

            // 用这个变量来保存输出的字符串
            StringBuilder returnstring = new StringBuilder();

            // GetInvocationList方法返回一个由Delegate引用构成的数组,
            //其中每一个数组都指向链中的一个委托对象。
            Delegate[] delegatearray = chain.GetInvocationList();

            // 遍历数组中的每个委托
            foreach (DelegateTest t in delegatearray)
            {
                try
                {
                    //调用委托获得返回值
                    returnstring.Append(t() + Environment.NewLine);
                }
                catch (Exception e)//异常
                {
                    returnstring.AppendFormat("异常从 {0} 方法中抛出, 异常信息为:{1}{2}", t.Method.Name, e.Message, Environment.NewLine);
                }
            }

            // 把结果返回给调用者
            return returnstring.ToString();
        }

    }
}
Program.cs

b.效果图:

【C#】C#委托学习第6张

免责声明:文章转载自《【C#】C#委托学习》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇SpringSecurity自定义AuthenticationProvider和AuthenticationFilter[学习日记]在文本框最前面一行追加新内容的一个SUB下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

h5页面下拉到底部加载下一页数据

Id=“+data[i].Id+”&f=“+first+”&s=“+second+”'˃“+data[1i].Title+”“+data[i].PublishTime+”“);}},错误:函数{$.removeClass.text('数据加载失败,请重试!...

Linux系统glibc库版本信息查看

有时我们经常需要检查当前系统的glibc版本。您可以按如下方式进行检查:/lib/libc。所以。6有时:/lib/x86-64-linux/libc。因此6.将文件作为命令执行。为什么库可以直接运行?Glibc是gnu发布的libc库,即c运行时。glibc是linux系统中最低级别的api,几乎任何其他运行时都将依赖glibc。Gcc和libc是相互依赖...

pycharm最新版本激活码(永久有效) python安装教程

输入python以查看当前版本的python。您可以输入“print'helloworld”并单击下载以启动PyCharm://pan.baidu.com//1eVdm4dUPKn3ZY_Xj kqNXw提取代码:l83f2,下载破解补丁(版本2018.3.5)下载链接至地址:...

jenkins之部署、启动、关闭

jenkins可以通过内置的应用服务器或者借助其他应用服务器启动目录1、启动jenkins2、关闭jenkins3、重启jenkins4、重新加载jenkins配置信息前言:部署jenkins应用,是要安装java的,最新版本的jenkins是需要按照1.8版本的jdk,不然启动不了。...

ORACLE无法删除当前连接用户

今天在做Oracle数据库是遇到ORACLE无法删除当前连接用户,经查找可用如下方法解决。SQL˃dropuseracascade;//删除用户以及用户表空间下所有对象用户已丢弃。...

svn文件冲突,树冲突详解

文件冲突当两名或更多开发人员修改了同一个文件中相邻或相同的行时就会发生文件冲突。这个操作会出现一个对话框,列出文件夹下所有有冲突的文件,你可以选择将哪些标记成已解决。因此即使它是树冲突的一部分,却既不能显示冲突的叠加图标也不能通过右键单击来解决冲突。在此案例中,使用冲突编辑对话框中的删除按钮进行清理并将冲突标记为已解决。Foo.c被标记为删除并且产生一个树冲...