重读COM技术内幕(inside com)有感

面向对象设计哲学在复杂领域并不能很好地解决问题。参考(http://www.richardlord.net/blog/what-is-an-entity-framework)。因此引入了面向接口的设计。微软组件对象模型就是这种设计的实现。当然,COM的应用绝对不限于Microsoft,而COM的底层架构也由于实现过于复杂带来很多性能上的问题。但是COM的思想的确有伟大之处。

动态决定一个对象能调用哪些方法是现今软件领域配置即服务的根本要求。对象不能固化;对象实现的接口也不能固化;对象从配置文件中读取配置以动态实现接口。这样一来,对象就是泛化的实体(Entity),接口如果称为组件(Component),那么组合优于继承,就是这个意思了。Entity包含了不同的Component,这样Entity就形成不同类型的对象或服务。而处理对象的流程(Process,也有称System)就是根据一定规则调用Entity服务的过程。这样一来,一切都豁然开朗了。

让我们再梳理一下思路。软件就是服务,这没错。服务就是一些部分(Component)的组合。每个部分完成具体的功能调用。组合这些部分(Component)就形成具有有种特性的实体Entity。所有Entity都应该具备查询是否支持某个Component的方法,于是IUnknown接口被抽象出来,作为所有Component都支持的接口(Interface)。Interface就是方法集合,暴露Component的功能。Component正因为具备了不同的Interface,于是成为特定的组件。Component包含数据和逻辑,而Entity组合他们。

注册表毫无意义。组件系统本身不应该依赖第3方提供的清单来发现。注册表机制的最大缺陷成为它日后被广泛攻击的靶子,最后是Windows最脆弱的部分,衍生出巨大的灰色市场。微软当初的软件哲学是封闭的黑盒子调用,所有要通过注册表机制来发现服务。某个功能既然有人实现了,就可以放到一个中心化的地方备案,然后调用者可以放心使用。这个哲学最大的出发点就是封闭。COM的衰落也是由于封闭导致。其实调用别人写好的组件并不是真正意义上的重用,这种仅仅靠数字签名没有任何保证的调用,会带来巨大的隐患。软件在工程领域真正的重用必然需要源码开放。软件本身应该成为闭包,不应该依赖系统过分的参与(脚本宿主除外)。

既然COM其核心思想如此通用,COM本来应该就是跨平台的,但是由于历史的原因,长久以来COM及其类库被绑定在Windows平台上。当然,现在看来,其核心类库已然不足取,完全可以自己根据这个思想灵活对待具体问题。

今天,使用高级语言Java, C++等开发的,鲜有不是面向接口开发的。在Java里,可以很容易判断一个对象是否实现了某个接口,在C++里,需要提供一个公共方法。面向组件开发的最大有点就是可以动态配置接口,引入脚本支持,比如lua,实现热部署,热替换,仅仅配置就可以实现功能了。今天重读COM技术内幕,10多年前的心境油然而升,当年是啃了一年啃出来的一本书,现在看来是那么轻松。当然,如果你是个新手,这本书可以看,但不要局限在微软对象模型上,重点是理解其思想,自己实现一个平台无关版本就可以了。取其精华,去其糟粕。

重读COM技术内幕(inside com)有感的更多相关文章

  1. 【Sql server: T-Sql 技术内幕 系列】之索引篇

    本文系 T-Sql技术内幕系列读后感. 用过数据库的程序猿都知道,索引可以极大的优化sql语句的执行时间,但是您要问我,怎么减少的,我只能说:"抱歉,我也不太清楚." 带着这个疑惑 ...

  2. 【转】COM技术内幕(笔记)

    COM技术内幕(笔记) COM--到底是什么?--COM标准的要点介绍,它被设计用来解决什么问题?基本元素的定义--COM术语以及这些术语的含义.使用和处理COM对象--如何创建.使用和销毁COM对象 ...

  3. 《[MySQL技术内幕:SQL编程》读书笔记

    <[MySQL技术内幕:SQL编程>读书笔记 2019年3月31日23:12:11 严禁转载!!! <MySQL技术内幕:SQL编程>这本书是我比较喜欢的一位国内作者姜承尧, ...

  4. SQL Server技术内幕笔记合集

    SQL Server技术内幕笔记合集 发这一篇文章主要是方便大家找到我的笔记入口,方便大家o(∩_∩)o Microsoft SQL Server 6.5 技术内幕 笔记http://www.cnbl ...

  5. 《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(下)

    索引: 一.SQL Server的体系结构 二.查询 三.表表达式 四.集合运算 五.透视.逆透视及分组 六.数据修改 七.事务和并发 八.可编程对象 五.透视.逆透视及分组 5.1 透视 所谓透视( ...

  6. 《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(上)

    索引: 一.SQL Server的体系结构 二.查询 三.表表达式 四.集合运算 五.透视.逆透视及分组 六.数据修改 七.事务和并发 八.可编程对象 一.SQL Server体系结构 1.1 数据库 ...

  7. Mysql技术内幕(第四版)读书笔记(一)

    题记:写代码已经有2年了,学到了很多知识,但是没有一个好习惯去记录,去分享,好多知识点都会忘记,所以从今天开始学着像大牛一样去记录自己经历项目的点点滴滴,先从最近读<Mysql技术内幕>开 ...

  8. 深入分析Java Web技术内幕(修订版)

    阿里巴巴集团技术丛书 深入分析Java Web技术内幕(修订版)(阿里巴巴集团技术丛书.技术大牛范禹.玉伯.毕玄联合力荐!大型互联网公司开发应用实践!) 许令波 著   ISBN 978-7-121- ...

  9. WebKit技术内幕

    WebKit技术内幕(浏览器内核|渲染引擎| HTML5| Chromium项目Committer重磅作品) 朱永盛 著   ISBN 978-7-121-22964-0 2014年6月出版 定价:7 ...

随机推荐

  1. ●BZOJ 3994 [SDOI2015]约数个数和

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3994 题解: 莫比乌斯反演 (先定义这样一个符号[x],如果x为true,则[x]=1,否则 ...

  2. [APIO2013]

    A.机器人 题目大意:给定一个n*m的地图,有一些障碍物和k个机器人,你每次可以选择一个机器人往任意一个方向推,遇到转向器会转向,两个编号相邻的机器人可以合并,求最少推多少次可以全部合并. $n,m\ ...

  3. python3 条件判断,循环,三元表达式

    一. 条件判断 条件判断的关键字if elif else,具体规则如下: if condition_1: statement_block_1 elif condition_2: statement_b ...

  4. Android通过聚合数据API实现天气预报

    使用聚合数据的API 聚合数据地址:https://www.juhe.cn/ 在数据服务->生活常用->全国天气预报,申请天气预报的API使用的KEY 保存请求示例的地址,把您申请的KEY ...

  5. 【js-xlsx和file-saver插件】前端导出数据到excel

    最近在做项目,前端进行处理数据,导出excel中,还是遇到不少问题,这里将其进行总结一下,博主是vue框架开发,借用file-saver和xlsx插件进行导出excel,我们来看下代码和效果.地址链接 ...

  6. IBM-x3650做RAID5更换硬盘后rebuild步骤分享

    1.按Ctrl+H进入WebBIOS配置 2.点击start 3.点击Drives,对slot5进行配置 4.选择slot5,选择Properties,点击Go按钮 5.选择MakeUnconfGoo ...

  7. SQL Server用户自定义数据类型

    用户自定义数据类型:基于系统数据类型,由数据库管理员生成.利用系统存储过程定义用户自定义数据类型` Sp_addtype [@typename=] 新数据类型名, [@phystype=] 系统数据类 ...

  8. bootstrap table 和 x-editable 使用方法

    最近需要做一些数据表格,有同事推荐EasyUI,但经过比较还是选择了Bootstrap,一款极为强大的表格组件,基于Bootstrap 的 jQuery .本文还将介绍Bootstrap-editab ...

  9. hive升级遇到的几个小问题

    1.hiveserver2正常启动,但是beeline连不上服务. 我的服务是开在本机的,但是用主机名和127好像都不能访问服务了 jdbc:hive2://172.19.1.11:10000> ...

  10. 异常处理&RandomAccessFile&节奏感

    异常处理 异常处理方面的知识,下面是学习中记的笔记: try尝试捕获异常 catch对捕获的异常进行处理 多个catch要注意的问题: 一.顺序问题,先小后大,也就是先子类后父类.因为当异常出现的时候 ...