工行的BICE有一个很有趣的功能,我们开发的通讯组件代码,.class文件只要放到服务端的指定目录下,并在配置文件中配置相应的信息,这样BICE就可以在运行时动态的创建我们的通讯组件类对象,进而使用它(虽然BICE要重启才能生效,但是我认为需要重启与BICE设计时的实现有关,而JAVA本身是能够实现动态加载类,并生成类对象的).JAVA程序员都知道这是利用了JAVA的强大的反射功能.
无独有偶,C#是模仿JAVA的语言(不可否认,微软是看到了JAVA的强大嫉妒了).C#也可以通过加载.DLL(相当于JAVA的.class都是动态库),实现类似于上述BICE的功能.
上一篇文章中提到了C++实现反射的一个方法,其实只是实现了动态创建,能否利用.DLL和配置文件,实现程序运行时动态加载后面开发的类,还有待验证(不管如何,C++肯定是可以实现这个功能的)
说了这么多,其实我是想到这些应用和插件的开发很相似.应用程序在运行时通过插件动态的扩展功能,这不就和上面BICE的功能很相似吗.插件的一种实现策略就是通过.DLL实现的,大胆猜想,程序运行时,通过动态加载.DLL,从而扩展应用程序的功能.当然,这个.DLL要遵循应用程序公布的规范.
所以,我认为研究插件,对于框架设计和C++的反射如何实现是大有辟益的.
其实,说白了,我们为BICE开发的通讯组件就是一个插件,只不过在BICE主程序里少了对于插件的安全性检查等东西罢了.