委托解耦
程序员文章站
2022-05-03 15:08:34
发布者订阅模式/客户端模式 对象与对象之间不可以直接调用其成员。如果直接调用其他对象的成员那么就是一个紧耦合。 1. 1.删除系统为我们准备的窗体。创建一个窗体应用程序 2.创建两个窗体对象,一个父窗体一个子窗体 3.在Program程序中修改程序启动窗体为父窗体 2. 1.为我们的两个窗体添加同样 ......
发布者订阅模式/客户端模式
对象与对象之间不可以直接调用其成员。如果直接调用其他对象的成员那么就是一个紧耦合。
--------1.
1.删除系统为我们准备的窗体。创建一个窗体应用程序
2.创建两个窗体对象,一个父窗体一个子窗体
3.在program程序中修改程序启动窗体为父窗体
--------2.
1.为我们的两个窗体添加同样的控件
2.空间名称相同
--------3.
打开父窗体的代码
public childfrm childfrm { get; set; }//父窗口属性 private void parentfrm_load(object sender, eventargs e) { this.childfrm = new childfrm(); childfrm.show(); }
--------4.
我们在这里添加的代码作用在于:
添加了一个委托为我们对象与对象之间的解耦而存在。
我们在一个对象中我们需要尽量的避免对像与对象之间的耦合。该委托为下文做准备
public action<textbox> sendtochild { get; set; }//委托{可重用性} public childfrm childfrm { get; set; }//父窗口属性 private void parentfrm_load(object sender, eventargs e) { this.childfrm = new childfrm(); sendtochild += childfrm.teststring;//多播委托,此委托链接一个方法,方法会转换为委托实例。 childfrm.objecttosend(this); childfrm.show(); }
--------5.
创建了一个工厂方法,该方法我们用来检查传递进来的参数是否有错误的存在
public void teststring(textbox x) {//根据外面传来的值我们决定是否操作。 this.txtmsg.text = x.text; }
--------6.
我们在子窗体中声明了一个方法,该方法只处理传递进来的一个参数,与外部对象实现了一种解耦
public static class control { public static void showchildsendcontrol<t>(action<t> actio, t x) {//工厂方法,检查是否曾在错误 try { if (actio != null || x != null) actio.invoke(x); return; } catch { console.writeline("出现异常"); } } }
--------7.
添加了一个触发按钮的事件,该事件触发时内部会调用我们的委托,该委托已经指向了一个方法,这个委托作为工厂方法的一个参数传递,目的在于我们在工厂方法内进行检查,提高了代码的复用性。
private void btnsendmsg_click(object sender, eventargs e) {//父窗口像别的窗口传值 control.showchildsendcontrol(this.sendtochild, this.txtmsg); this.txtmsg.clear(); }
上一篇: efcore mysql数据库codefirst生成
下一篇: C#各种字段类型对比