评C#事件处理

原创 2004年04月21日 13:56:00

前几天学了一点C#,没当真的。因为要搞《MSDN开发精选》的缘故,完全不懂也说不过去。没看什么语言方面的书。也就是把Jefferey Richter的《Applied .NET Framework》(李建忠译本)找来翻翻。看到event那一部分就烦了,原来C#的delegate和event只是表面光,下面的实现还是非常笨重。一个长长的链表,里面放着闭包指针,类型是够安全了,付出的空间和时间效率都不小。对我我这种从C语言爬过来的人,就是觉得不爽。

事件处理机制是C++及其后继者(Java、C#)的最大软肋之一。本质上是因为C++当年的选择,把对象之间的普通消息传递用成员函数调用给解决了。成员函数调用快是够快,但是导致了消息发送者与接受者之间的紧耦合。大多数情况下这倒也并不是什么大不了的事,偏偏在事件处理上,实践中需要松耦合,于是C++的问题就暴露出来了。君不见,所有用C++写的GUI Framework都在event这件事情上大做文章。比较笨的如MFC的全局映射表,比较聪明的如Qt的Signal/Slot,一个例外是VCL,Borland实现了closure指针,把caller context跟指针绑到一起发送给callee,Java比较中规中矩,按照最OO的方式实现了事件处理机制,但是可扩充性不好。C#的delegate其实就是VCL中closure指针的新版。总之是八仙过海,各显其能。但是我觉得,都是在C++已经走歪的老路上徒然努力。只要这个思路还在,事件处理就不可能非常elegant。C#可以让整件事情在表面上看起来很漂亮,可是骨子里还是邋遢的。

就个人而言,我还是比较欣赏C的办法:规定一个协议,我把event数据准备好放在一个地方,然后就不管了,事件的接受者自己去取数据,自己解析,自己决定如何处理。

这样的接受者,在对象分类中,叫做主动对象——active object。这两年在embedded system programming中间,大家越来越发现主动对象的种种优势。我个人觉得主流编程领域也应该考虑一下这个问题。

主动对象的问题可能是类型不安全,但实际上类型安全没有那么重要, 没必要死抱住不放。原来C语言里:
int (*compare)();
声明的指针可以指向任何返回整数的函数,不管其参数列表如何。在C++里面,这个指针只能指向一个返回整数的无参函数了,灵活性大大降低。也难怪open source人士还是偏爱C。虽然安全性和灵活性同等重要,但是真正的黑客可以用自己的技术来保障安全性,却无法接受灵活性的缺失。

扯远了。

总之,看得越多,越觉得C真是一种伟大的语言,大概只有Fortran和LISP跟它处于同一级别。

附带提一句,李建忠翻译的质量极高,令我辈叹服。

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

以考代评职称的新诱惑

职称这个名词也许大家并不陌生,工程师、教授、建筑师之类的头衔,在各种电视剧中都能经常听到。不过职称的作用很多人都不知晓,或者了解得不全面。事实上,职称是一个具有强烈政策气味的专业人才概念,它在很多单位...
  • l472995348
  • l472995348
  • 2014年05月15日 17:27
  • 1410

正方教务系统一键评教代码

正方教务管理系统一键评价、一键评教Javascript代码
  • ligaopeng001
  • ligaopeng001
  • 2017年01月13日 13:54
  • 1050

评教脚本-浙传

献给浙传的孩纸们,快速评教脚本! 注意:浏览器必须是IE9以上。建议使用chrome浏览器。       1.打开评教系统选择某位...
  • rock_lv
  • rock_lv
  • 2016年06月16日 11:03
  • 1353

评标客观分,不“客观一致”导致中标无效是谁的责任

【案情概述】  20××年4月30日,K招标公司接受采购人委托,就该单位“网络设备采购及安装项目”组织公开招标工作。4月14日,采购人确认了招标文件;K招标公司在中国政府采购网上发布了招标公告。...
  • ebidding007
  • ebidding007
  • 2016年12月21日 14:52
  • 301

vue-star评星组件开发

star文件夹下建立Star.vue,及相关的图片信息。便于组件的就近维护 Star.vue: ...
  • u013217071
  • u013217071
  • 2017年06月06日 10:00
  • 1534

纯js评星插件

其他的我就不多说直接上源码 #xingp{ width: 125px; height: 25px; } .pxgz{ width: 20px; height: 25px; float: le...
  • lllzzzeee
  • lllzzzeee
  • 2015年08月03日 22:23
  • 457

【小蒙淘金】1.13周评-多空博弈激烈,胜负难分

【小蒙淘金】1.13周评-多空博弈激烈,胜负难分      【前话】   最近很多出现亏损的投资朋友找到我,经本人了解,总结出以下几点原因:   第一、对投资的认识层面太低,对风险的管控毫无知...
  • xiaomengtaojin
  • xiaomengtaojin
  • 2013年01月13日 21:07
  • 251

每月自评之一:2013年1月

(一)我读      本月阅读过的书籍:      (1)《程序员的职业素养》           1)推荐指数:四星           2)简评:Bob大叔的职业生涯经验总结,现身说法...
  • stanjiang2010
  • stanjiang2010
  • 2013年03月02日 17:17
  • 1934

项目经理之项目经理的基本特征

很多组织内部,项目经理在企业的开发工作中充当一个关键的角色。一个成功的项目经理必须能够在一个高度变动的环境中和紧张的条件下工作。     项目经理的效能通常要依赖天生的、个人的技能以及所学习的项目管理...
  • taomanman
  • taomanman
  • 2016年02月29日 13:22
  • 1271

iOS app store审核规则汇总,你会被拒吗?

先从官方的Guide文档来看容易犯的错误:
  • gwgking2012
  • gwgking2012
  • 2014年11月24日 11:30
  • 1579
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:评C#事件处理
举报原因:
原因补充:

(最多只允许输入30个字)