c#---委托到底是什麽,爲麽需要委托

本文通过生动的例子解释了C#中委托的概念,将其比作现实生活中的快递委托过程,阐述了委托在面向对象编程中解决继承弊端的作用,以及如何在C#中声明和使用委托。

委托到底是什麽,爲麽需要委托

首先,我們來説説面向對象,所謂面向對象是對不同職階的地位對象的封裝,通俗的說就是專業的事情交給專業的人做;又比如在《fate》中具有七個職階,不同的職階都有其自己的專屬技能和所擅長的領域。
然而,對象想學習新的技能就得繼承繼承的弊端在于會使一個類過於龐大而且有些方法,并不是我們現在的這個子類所需要的。
來到這裏,就有我們的委托了。我們日常生活中的委托是這樣子的,我們就將我們的快遞交給快遞小哥(我們委托小哥送快遞),但是快遞小哥不僅接受我們的委托還可以接受多個人的委托的嘛(委托的包裝特性,能夠將各個類的方法 組裝到一個委托中),到約定的時間(調用組裝的方法),快遞小哥就給我們把快遞送到指定的客戶手中。

如何用

class program1:

class Program1
    {
        void printLow()//組裝的函數的返回類型與簽名要與委托的聲明保持一致
        {
            Console.WriteLine("{0}-Low Value", "L");
        }
    
     }

class progaram2:

class Program2
    {
        void printHeight()//組裝的函數的返回類型與簽名要與委托的聲明保持一致
        {
            Console.WriteLine("{0}-Hight Value", "H");
        }

Main

using System;

namespace Del
{
    delegate void MylDel(int value);			//第一步:聲明委托類型
    
        static void Main()
        {
            Program1 program1 = new Program1(); //聲明變量program1 
            									//引用Program1()實例對象
            
            Program2 program2 = new Program1();	//聲明變量program2 
            									//引用Program2()實例對象

            MylDel del; 						//第二步:聲明委托變量

            //創建一個包含PrintLow和PrintHight的委托對象並將其賦值給del變量
            del =  new MylDel( 					//引用實例化對象
                program1.printLow 
            );
            del+=program2.printHeight			//添加方法

            del();								//執行委托 調用委托中的所有方法
        }
    }
}

參考

《C#圖解教程》—第十三章 委托 P238~248

如何通俗易懂的理解c#中的委托和事件,另外,.net和c#有哪些具体的关系?

内容概要:本文围绕基于模型预测控制(MPC)与滚动时域估计(MHE)集成的目标点镇定方法展开深入研究,重点探讨其在六自由度机械臂系统中的应用,并提供了完整的Matlab代码实现。研究充分结合MPC的多步预测、滚动优化与反馈校正能力,以及MHE对系统内部状态的高精度在线估计优势,构建了协同工作的闭环控制架构,实现了复杂非线性系统下对目标点的高精度、强鲁棒性镇定控制。文中系统阐述了MPC预测模型的建立、代价函数的设计、状态与输入约束的处理机制,以及MHE基于优化准则进行状态估计的实现流程,详细展示了算法的整体设计思路、数值实现步骤与仿真验证过程。通过仿真实验验证了该集成策略在抑制外部干扰、补偿模型不确定性方面的优越性能。此外,资源还整合了多种先进控制技术与优化算法的仿真案例,涵盖机器人、电力电子、智能交通等多个领域,为科研人员提供丰富的算法复现与工程参考资源。; 适合人群:具备一定控制理论基础和Matlab编程能力,从事自动化、机器人、电力电子、智能系统等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:① 习并掌握MPC与MHE联合控制策略的设计原理与代码实现方法;② 应用于机械臂、无人机、智能车辆等复杂系统的高精度运动控制与状态估计任务;③ 为科研论文复现、工程项目开发及先进控制算法的优化改进提供可运行、可调试的代码基础。; 阅读建议:建议结合文中的算法理论描述与Matlab代码进行同步研读,重点关注MPC中预测模型构建、权重矩阵整定、约束处理以及MHE状态估计的优化求解实现细节,鼓励在仿真环境中动手调试参数,有条件的情况下可进一步在实际物理系统或高保真模型中进行验证与性能评估。
内容概要:本文研究了基于自适应状态相关黎卡提方程(SDRE)的非线性无传感器速度控制方法在永磁同步电机(PMSM)驱动系统中的应用,并通过Simulink进行仿真验证。该方法摒弃传统机械传感器,构建高精度非线性状态观测器,结合自适应SDRE控制器实现对电机转速与位置的实时估计与闭环控制,有效克服系统参数摄动、外部负载扰动及建模不确定性带来的影响。研究重点在于设计具备在线调节能力的状态反馈增益机制,通过求解时变的代数黎卡提方程实现动态最优控制律,从而在宽速域范围内,尤其是在低速与零速工况下,显著提升速度跟踪精度、系统鲁棒性与动态响应性能。仿真结果充分验证了该控制策略在抑制转速波动、加快响应速度、增强抗干扰能力以及保障系统稳定性方面的优越性,为高性能PMSM无传感器驱动提供了先进的技术解决方案。; 适合人群:电气工程、自动化、电机与控制相关专业的研究生、科研人员及从事PMSM驱动系统开发的工程技术人员。; 使用场景及目标:①应用于对可靠性与维护成本敏感的高精度工业驱动系统,如精密机床、电动汽车、航空航天设备中,替代传统依赖速度传感器的控制方案,降低系统成本与故障率;②为先进无传感器控制算法的研究与教提供坚实的理论依据与可复现的仿真范例;③支持研究人员深入探索非线性控制理论、自适应观测器设计、最优控制策略在电机驱动领域的深度融合与实践验证。; 阅读建议:建议读者结合提供的Simulink模型进行同步仿真运行,深入剖析SDRE控制器的状态空间建模过程、雅可比矩阵线性化处理方法以及Riccati方程求解器的实现细节,重点关注系统稳定性证明与收敛性分析,同时可将其与滑模观测器(SMO)、扩展卡尔曼滤波(EKF)等主流无传感器技术进行对比研究,以全面评估其性能优势与适用边界。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值