通用类库

一、 什么是通用类库
   通用类库是特定编程语言在各种平台都获得支持的类库环境(编程环境和或运行环境)。举例说来就是C++的strcmp函数,能在各个平台无需修改直接使 用。但是,我们知道,完全的通用是不可能的,普遍的通用已经很困难了。所以本为讨论Linux和Windows的通用类库的建设和设计考虑。
  
二、 为什么是现在
     时下Linux越来越红火,我们假定占有率有10%(包括D版),那么你的10个朋友中有一个使用Linux,当某个朋友问你什么功能如何设置的时候,你的第一个问题可能是:什么操作系统?
     再看政府方面的软件,10%的占有率似乎触手可及,作为政府软件供应商,不得不考虑Linux和Windows之间的通用类库的问题。简单的说,如果你放 弃10%的Linux用户就是失去10%的机会;另一方面,如果基于通用类库开发软件所需要的额外费用低于10%就是有利可图。作为通用类库的提供者就在 这10%的额外费用中抽取所需。当Linux占有率越来越高,通用类库的提供者的利益就越来越多。
     不要忘了,如果打算提供这方面的类库,那么应该预留18个月给你的下家,而下家在18个月后考虑他的18个月的最终用户会使用什么。所以我们现在考虑的是36个月后的情况。
  
三、 基本要素
(1) GDI/GUI
(2) 数据库
(3) 通讯
(4) 远程调用/协同计算
(5) 数据交换
(6) 消息机制
(7) 进程线程
(8) 同步机制
(9) 驱动程序
(10) 重用模式
(11) 互调接口
(12) XML支持
(13) 开发/调试工具
(14) WebService支持

四、 Java未完成的任务
     Java在通用类库方面做得十分优秀。以上各种要素中除了驱动以外都有很好的支持。驱动也可以通过JNI来获得支持,只是没有获得更广泛的使用而已。由于 执行效率的问题在关键任务中的不到应用。据说不久的将来6.0通过编译API可以编译成机器码再执行,相信这方面的瓶颈得到一定的缓解。

五、 C / C ++未完成的任务
     其实C/C++有着比Java更丰富的通用类库。所以,绝大多数的嵌入式用C/C++编写,操作系统用C/C++编写等等。但是在现代的编程环境中上述的 前3项(GDI/GUI,数据库,通讯),都没有得到很好的通用支持,只记得Borland的CLX做过这样的尝试。
    
六、 建设通用类库
     那么,我们如何建设通用类库?首先要考虑的是使用什么语言。Java通用性强,执行效率如果不是苛刻,那是可以满足的。C++执行效率高,在更多的场合得 到应用,但是入门门槛高,造就了高成本。WebService也有一定的通用性,因为Apache能运行于Windows和Linux。如果自己编写所需 的语言,也不是没有可能,不过要把上述的基本要素都编写全,是在非一般公司能做到,除非那种语言有现有的语言所不能代替的优点。其次是考虑现有的成果。现 有的成果包括组织自身的历史成果和其他供应商(编程语言供应商)所提供的成果。
     一般而言,处于上游的开发商更倾向于组织自身的历史成果,即使没有这方面的现成成果,也很少考虑其他供应商所提供的成果。而处于下游的开发商更倾向于其他供应商所提供的成果。
     现在具体的说一下,要建设专用的数据库管理系统(例如医疗,流通/物流,OA,财务)等等,很显然是处于下游,如果建立业务逻辑就是核心竞争力,需要更多 的使用非自身的其他供应商所提供的成果。在这种情况下,那么更多倾向于Java或WebService这边了。如果外观和成本是核心竞争力,那么通用类库 于你无缘,一般使用微软的那套。
    
    
以上是粗浅见解,读者应该多多发表看法。

现在已经开发出来了,请多多指教
http://duceland.com/cn/dsRE.asp

在线文档
http://duceland.com/cn/dsRE_dev_doc.pdf

posted @ 2006-06-01 14:41  yesry  阅读(696)  评论(0编辑  收藏  举报