`
varsoft
  • 浏览: 2435190 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

评C#事件处理

阅读更多

前几天学了一点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跟它处于同一级别。

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

分享到:
评论

相关推荐

    Visual C# 2010 How To Program 4Th Edition

    后续内容主要涉及c#中的几种控制语句、方法的使用、数组、linq、类与对象、继承、多态、接口、运算符重载、异常处理、gui、字符串和字符处理、文件和流操作、数据库、asp.net、搜索与排序、数据结构、泛型、集合等。...

    C# 控制台应用程序——随机数

    5)了解C#的异常处理流程; 6)掌握C#的计时器及对代码的性能优化。 7)本实验注重算法实现,在实现功能的前提下,尽量优化计算速度。 2、实验要求 这是一个实际的项目衍生出来的核心算法之一。防伪码是我们...

    C# 4.0捷径教程 中文版 part2

    第7章 异常处理和异常安全 第8章 使用字符串 第9章 数组、集合类型和迭代器 第10章 委托、匿名方法和事件 第11章 泛型 第12章 c#中的线程 第13章 c#规范形式探索 第14章 扩展方法 第15章 lambda表达式

    C# 4.0捷径教程 中文版 part1

    第7章 异常处理和异常安全 第8章 使用字符串 第9章 数组、集合类型和迭代器 第10章 委托、匿名方法和事件 第11章 泛型 第12章 c#中的线程 第13章 c#规范形式探索 第14章 扩展方法 第15章 lambda表达式

    C#本质论第四版高清扫描文件

    《c#本质论(第4版)》共有21章和4个附录,介绍了c#语言的数据类型、操作符、方法、类、接口、异常处理等基本概念,深入讨论了泛型、迭代器、反射、线程和互操作性等高级主题,还介绍了linq技术,以及与其相关的扩展...

    大学专用智能评教系统源代码 论文设计全套文件

    C#做的智能评教系统,内含论文,是毕业设计时做的,供大家下载 ...【关键词】教学评估,智能评教,非法处理,智能评分,评教 议教 智能评教 评教系统 评教源码 毕业设计 论文设计 系统设计 C# 毕业论文 硕士论文

    微信公众平台 网页授权获取用户基本信息(asp.net C#)

    入口页面: wxProcess.aspx 【自己调通了非常喜悦。好东东,大家分享。 免积分,给个好评哦;)】 微信公众平台 网页授权获取... //或跳转到自己的页面,想怎么处理就怎么处理 Response.Redirect(reurl); } }

    教师评教智能评选系统

    系统的智能性主要体现在智能动态设计评选项目、动态生成评教界面、智能设置非法评教结果特征、根据学生学号智能提取被评教的教师名单、对单个评教结果智能分析(主要是指对合法的和非法的结果的不同处理)、评教结束...

    基于ASP.NET的智能评教系统设计与实现毕业设计(源代码+项目报告+开题报告+答辩PPT).zip

    系统的智能性主要体现在智能动态设计评选项目、动态生成评教界面、智能设置非法评教结果特征、根据学生学号智能提取被评教的教师名单、对单个评教结果智能分析(主要是指对合法的和非法的结果的不同处理)、评教结束...

    毕业设计:ASP.NET智能评教系统(源代码)

    系统主要使用C#语言来开发,C#语言的开发工具目前主要是微软的Microsoft Visual Studio.NET,该工具包含了.NET开发的各种语言。Visual Studio.NET从一开始就是为XML Web 服务创建的开发环境。通过允许应用程序通过...

    asp.net知识库

    在ASP.NET页面中推荐使用覆写(Override)而不是事件处理(Event Handler) 常用编码工具类,支持base64,md5,des,crc32 也谈谈技术面试 在C#里把ArrayList转换为Array 或 把Array转换为ArrayList C# 2.0 在.NET 2.0中...

    ASP+ACCESS网上评教系统设计(源代码+thesis+).zip

    我们将使用ASP.NET MVC框架和C#编程语言来实现这个项目。 ASP.NET MVC是一种成熟的开发框架,它采用模型-视图-控制器的设计模式,将应用程序的逻辑和界面分离,提供了更好的代码组织和可维护性。我们选择ASP.NET MVC...

    ASP.NET智能评教系统(源代码+thesis++replyPPT).zip

    我们将使用ASP.NET MVC框架和C#编程语言来实现这个项目。 ASP.NET MVC是一种成熟的开发框架,它采用模型-视图-控制器的设计模式,将应用程序的逻辑和界面分离,提供了更好的代码组织和可维护性。我们选择ASP.NET MVC...

    ASP+ACCESS网上评教系统(源代码+thesis+任务书).zip

    我们将使用ASP.NET MVC框架和C#编程语言来实现这个项目。 ASP.NET MVC是一种成熟的开发框架,它采用模型-视图-控制器的设计模式,将应用程序的逻辑和界面分离,提供了更好的代码组织和可维护性。我们选择ASP.NET MVC...

    ASP.NET 3.5 开发大全word课件

    4.3 代码隐藏页模型的事件驱动处理 4.4 ASP.NET客户端状态 4.4.1 视图状态 4.4.2 控件状态 4.4.3 隐藏域 4.4.4 Cookie 4.4.5 客户端状态维护 4.5 ASP.NET页面生命周期 4.6 ASP.NET生命周期中的事件 4.6.1 页面加载...

Global site tag (gtag.js) - Google Analytics