Plugin Series: 什么是Plugin

Plugin(Plug-in,addin,add-in,addon或add-on)是一种计算机应用程序,它和主应用程序(host application)互相交互,以提供特定的功能。应用程序支持Plugin有许多原因,一些主要原因包括:使得第三方开发者有能力扩展应用程序,以提供无法先期预料的特色;减小应用程序的大小;由于软件版权之间的不兼容性将源代码和应用程序分享。Plugin 通常译作插件,下文中以插件代替Plugin。

支持插件的软件例如有:

  • Email客户端 使用插件对email编码、解码
  • 图像软件 使用插件对文件格式进行支持和处理图像(Adobe Photoshop,AcdSee)
  • 媒体播放器 使用插件支持文件格式和应用过滤器(foobar2000, GStreamer, Quintessential, VST, Winamp, XMMS,WindowsMediaPlayer)
  • 包嗅探器 使用插件对包的格式进行解码 (OmniPeek)
  • 遥感应用 使用插件处理不同类型传感器的数据(Opticks)
  • 软件开发环境 使用插件支持不同的编程语言(Eclipse, NetBeans, jEdit, MonoDevelop)
  • Web浏览器 使用插件播放视频和媒体格式(Flash, QuickTime)
  • blog应用平台 使用插件增强blog功能(WordPress,LightPress, MovableType,Z-Blog)
  • blog终端 使用插件增加blog编辑功能(Windows Live Writer)
  • 文件编辑器 使用插件提供特定的文本编辑能力(Emeditor, Notepad++)
  • 编译任务管理软件 使用插件提供第三方语言支持或编译任务支持(Ant)
  • 企业Web应用平台 使用插件针对不同业务进行处理(Struts)

机制


主应用程序提供给插件可以使用的服务,让插件在主应用程序中注册插件本身,以及和插件进行数据交换的协议。插件依赖于主应用程序提供的这些服务,通常不能独立运行。相反地,主应用程序和插件是分离的,这就使得我们可以不改变主应用程序而动态增加或更新插件。

公开的应用程序接口(API)提供一个标准接口,允许第三方编写插件和主应用程序交互。一个稳定的API必须在主应用程序版本升级后第三方插件仍可以运行。插件同时也延长了过时的应用程序的生命。Adobe Photoshop 和 After Effects 提供给插件的API已经成为一种图像处理软件API的标准,被相类的图像处理软件所采纳。其它类似的API包括 Audio Units 和VST。

这种插件的机制很普遍,比如一个网络交换器,它有一个没被占用而且是非标准的端口,用它来接纳不同的任意的物理层连接;再比如计算机硬件制造业的行业标准架构(Industry Standard Architecture)和IBM著名的微通道架构(Micro Channel Architecture),都允许第三方设备。这些都是类似插件的一种机制。

插件和扩展


插件稍不同于扩展(extension),插件通常依赖于主应用程序的接口,有一个它们可以运行的确定的界限。扩展则通常有更少的限制,也可以提供它们自己的接口。相同的是,它们通常都用来减少主应用程序的大小、提供一些可选的功能。

这里不得不提到Mozilla Firefox 和相关软件。它们使用一个叫做Add-on的名词,Add-on又被细分为插件、主题(theme)、搜索引擎(search engine)和扩展。在以后的文章中将会提到Mozilla插件和古老的NPAPI的渊源,以及firefox中插件和扩展的区别。

历史渊源


插件的概念可以回朔到上世纪70年代。那时在Univac 90/60系列主机的Unisys VS/9 操作系统中,运行着一个叫 EDT 的文本编辑器,它提供一种功能可以从编辑器中运行其它应用程序,并允许这些程序访问编辑器的缓冲区,在内存中提供一种编辑会话。这样这些外来的应用程序就可以依靠共享的缓冲区执行文本操作了。这种功能后来被 Waterloo Fortran编译器使用,和EDT编辑的Fortran程序进行交互编译。

在PC机上拥有插件功能的第一个软件可能是在Macintosh上的HyperCard和QuarkXPress,它们在1987年发布。1988年,Silicon Beach软件公司在 Digital Darkroom和SuperPaint软件中也包含了插件功能。而Plug-in 这个名词则是被Ed Bomke提出。

Plugin 架构


以下按编程语言分类

C++
  • FxEngine Framework - 一个数据流处理框架
  • Qt PlugIns - TrollTech的 Qt 框架的一部分

Delphi
  • TMS Plugin Framework

Java
  • Java Plug-in Framework (JPF), 一种由Eclipse的插件机制而改写的架构
  • RCP, 由Eclipse发展而来的技术平台,应用程序可以以插件方式编写,应用程序本身也可以拥有插件

Python
  • Setuptools
  • The Twisted Plugin System
  • Sprinkles
  • Python plugin system

.NET
  • AL Platform
  • Mono Addins - .Net和Mono的一个addin框架
  • Code Project 基于.NET的插件框架

Active Visic
  • Active Visic

to be continued…


分享: Fanfou Misterwong-CN QQ Bookmark Baidu Bookmark del.icio.us Digg Google Yahoo! Yotie

永久链接   订阅

相关文章

4 Comments »

  1.  帕兰卓一得 said @ 1,

    November 7, 2007 @ 5:17 pm

    看的让人头晕。收下来,慢慢研究。

  2.  terababy said @ 2,

    November 7, 2007 @ 5:35 pm

    @帕兰卓一得 :-) 这些事得坐下来慢慢谈

  3.  AndyWxy said @ 3,

    November 7, 2007 @ 6:50 pm

    赞!非常详细的介绍,期待以后的文章~ :)

  4.  zhouqb said @ 4,

    November 7, 2007 @ 10:05 pm

    渊博……

订阅本文评注 RSS · TrackBack URI

Leave a Comment