[本人baidu博客全部搬家到csdn,baidu博客地址:http://hi.baidu.com/new/miracleconf]
跨平台GUI开发库
这篇内容有点专业,不搞开发的的可以飘过。
作为一个跨平台的GUI库,Qt算是老前辈了(据说tk是第一个真正的跨平台的GUI开发包,不知道有没有人验证过,但是用脚本写界面,这个好像不是主流吧)。网上搜索“跨平台GUI开发”应该可以得到不少对各个开发包进行比较的文章,这里说说我的感受:
Qt( http://www.trolltech.com/ )我最喜欢的东西,毕竟是商业的东西,没什么bug,文档详细,API接口也做得通俗易懂,对windows、Linux、MacOS的支持都堪称完美。在MFC的世界摸爬滚打之后,发现Qt对程序员来说真是一片空气清新的世外桃源——就是舒服。准确的说,Qt是一个完整的应用程序开发库,而不仅仅是GUI。比如线程、数据库、socket这些东西都有对应的封装。第一次接触Qt是在PDA上的Qtopia环境,Qtopia其实就是在Qt Embeded(不用Xwindows的Linux版Qt)系统中集成了很多应用软件,打成一个包,就像Windows mobile,主要的应用程序都有了,用户还可以再在上面装点自己的小程序。现在Qt都出到4.4版本了,据说相对于版本3主要的改动是矢量图形的支持,我没有用过。Google Earth就是用的Qt,可以看到qt-mt338.dll这个dll文件,说明它用的是3.3.8版本的带多线程支持的Qt。
Moto曾经在高端的Linux手机上都用Qtopia环境,如A600、A680什么的,那个时候Qtopia也是唯一在嵌入式GUI领域可以商业的Linux方案,GTK on Framebuffer还不那么稳定,后来Moto和一帮日本公司搞了那个Limo基金会,专门用GTK/Framebuffer做Linux方案。今年年初Trolltech被收购的时候,moto说Qt已经对它们不那么重要了,我也相信这是事实。
GTK( http://www.gtk.org/ )
这个现在应该是应用最广的了,LGPL发布。说实话,我不喜欢这个东西,从封装和API上看没有Qt做的好,而且做程序还必须要atk和pango的一系列依赖的包。Wireshark(原来的ethereal)就是用GTK开发的,所以移植到windows上也是用的windows版的gtk,看看Wireshark安装目录下的dll文件就知道gtk要依赖多少东西了。开发起来不爽。说了这么多GTK的坏话,再说点好的,gtkmm是一个gtk的C++封装,做的不错,一看代码风格也知道要现代一些,不知这个mm是什么意思;以gtk为基础的gnome桌面环境现在有Sun和Redhat、Ubuntu的人的商业化支持,所以是原来稳定性越好了。不像Qt为基础的KDE,好像一直没什么商业化的支持,在桌面环境中的日渐式微就不足为奇了,我怀疑商业公司都不是真的喜欢GPL的东西,GTK是LGPL的,商业公司很喜欢,基于GTK的软件哪天它不想开源了也可以。Qt从QPL转到GPL之后,也没有多少商业的支持。这些大公司如果做了一个基础构架,就GPL了一把,让别人都用我的东西,提高自己的影响力,而且用了的公司还也得开源。如果是一个业务层面的软件,大公司的产品就没有一个是开源的。好了,扯远了,GTK也是个不错的东西,FireFox都用它,我从来没有用它做过有点规模的开发还说了这么多坏话,估计rp值有所下降。
wxWidgets( http://wxwidgets.org/ )
原名叫wxwindows,这个也不错,从API和编程风格上,模仿MFC的痕迹比较重,但是封装的很多类比MFC更高级。作为一个开源社区维护的产品,文档写的相当不错。从MFC转到这个上面很容易,开发社区一直比较活跃,还有一个xrc扩展可以用xml来定义界面。这个应该是跨的平台最多的一个开发包了。不过wxwidgets的代码质量和Qt相比应该还是有差距,我在开发中就发现了其中的两个bug(好像那个时候还是2.4版本),但是瑕不掩瑜,总体来说wx做的相当不错,连Apple的MacOS中默认安装都自带wx的运行环境,可见其影响力。另外要说的是,wx从以开始就做了很好的python绑定,叫做wxPython,和wx本身同步更新,基本上现在是python做界面开发的首选GUI库。比如原版的BitTorrent,界面就是用wxPython写的。尽管PyQt和PyGTK都在发展,都有人用,但是在Python的名下,风头似乎不及wxwidgets。上面说用脚本写界面似乎不是主流,但是在Python崛起之后,这个也不好说了。另外要说一点是:在X11上的wxwidgets有三个版本,一是直接用X库的wxX11,一个是基于GTK的wxGTK,还有基于Motif的wxMotif(开发不太活跃)。wxGTK要稳定一些。
Fox Toolkits( http://www.fox-toolkit.org/ )
说实话,没有真正用过,好像一直也还比较活跃,毕竟能撑到现在的GUI库都是有些实力的。
下面是我的比较:
- Qt is the best one. 稳定,一个开发包搞定所有,不好的一点是编译很慢,相当慢,C++的通病啊。Qt Embedded应该是第一个不用Xwindow的linux图形环境吧,赞一个。想学习Linux下的GUI开发,应该从这个入手。甚至可以在VC用Qt的插件开发,做完程序到Linux下重新编译一下就OK了。
- GTK,API相对有点复杂,但是在内存占用上相对而言有优势,说道这里再骂两句Xwindow,一个工具栏上的Applet就要驻留10M内存,太烂了吧。GTKmm封装的不错。在windows下开发GTK程序没有Qt那么方便,搭环境就比较复杂,还是在Linux下开发吧。
- wxWidgets,移植MFC的程序到Linux下的话当然是用它了。或者你在给Python写界面程序,那就用Ulipad,用wxPython写的一个python集成环境。
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
C++类库介绍
再次体现了C++保持核心语言的效率同时大力发展应用库的发展趋势!!在C++中,库的地位是非常高的。C++之父 Bjarne Stroustrup先生多次表示了设计库来扩充功能要好过设计更多的语法的言论。现实中,C++的库门类繁多,解决的问题也是极其广泛,库从轻量级到重量级的都有。不少都是让人眼界大开,亦或是望而生叹的思维杰作。由于库的数量非常庞大,而且限于笔者水平,其中很多并不了解。所以文中所提的一些库都是比较著名的大型库。
标准库
标准库中提供了C++程序的基本设施。虽然C++标准库随着C++标准折腾了许多年,直到标准的出台才正式定型,但是在标准库的实现上却很令人欣慰得看到多种实现,并且已被实践证明为有工业级别强度的佳作。
1、 Dinkumware C++ Library
参考站点:http://www.dinkumware.com/'>http://www.dinkumware.com/
P.J. Plauger编写的高品质的标准库。P.J. Plauger博士是Dr. Dobb's程序设计杰出奖的获得者。其编写的库长期被Microsoft采用,并且最近Borland也取得了其OEM的license,在其C/C+ +的产品中采用Dinkumware的库。
2、 RogueWave Standard C++ Library
参考站点:http://www.roguewave.com/'>http://www.roguewave.com/'>http://www.roguewave.com/'>http://www.roguewave.com/
这个库在Borland C++ Builder的早期版本中曾经被采用,后来被其他的库给替换了。笔者不推荐使用。
3、SGI STL
参考站点:http://www.roguewave.com/'>http://www.roguewave.com/'>http://www.roguewave.com/'>http://www.roguewave.com/
SGI公司的C++标准模版库。
4、STLport
参考站点:http://www.stlport.org/'>http://www.stlport.org/
SGI STL库的跨平台可移植版本。
准标准库——Boost
Boost 库是一个经过千锤百炼、可移植、提供源代码的C++库,作为标准库的后备,是C++标准化进程的发动机之一。 Boost库由C++标准委员会库工作组成员发起,在C++社区中影响甚大,其成员已近2000人。 Boost库为我们带来了最新、最酷、最实用的技术,是不折不扣的"准"标准库。
Boost中比较有名气的有这么几个库:
Regex
正则表达式库
Spirit
LL parser framework,用C++代码直接表达EBNF
Graph
图组件和算法
Lambda
在调用的地方定义短小匿名的函数对象,很实用的functional功能
concept check
检查泛型编程中的concept
Mpl
用模板实现的元编程框架
Thread
可移植的C++多线程库
Python
把C++类和函数映射到Python之中
Pool
内存池管理
smart_ptr
5个智能指针,学习智能指针必读,一份不错的参考是来自CUJ的文章:
Smart Pointers in Boost,哦,这篇文章可以查到,CUJ是提供在线浏览的。中文版见笔者在《Dr. Dobb's Journal软件研发杂志》第7辑上的译文。
Boost 总体来说是实用价值很高,质量很高的库。并且由于其对跨平台的强调,对标准C++的强调,是编写平台无关,现代C++的开发者必备的工具。但是Boost 中也有很多是实验性质的东西,在实际的开发中实用需要谨慎。并且很多Boost中的库功能堪称对语言功能的扩展,其构造用尽精巧的手法,不要贸然的花费时间研读。Boost另外一面,比如Graph这样的库则是具有工业强度,结构良好,非常值得研读的精品代码,并且也可以放心的在产品代码中多多利用。
参考站点:http://www.boost.org'>http://www.boost.org(国内镜像:http://www.c'> http://www.c'>http://www.c'>http://www.c-view.org/tech/lib/boost/index.htm)
GUI
在众多C++的库中,GUI部分的库算是比较繁荣,也比较引人注目的。在实际开发中,GUI库的选择也是非常重要的一件事情,下面我们综述一下可选择的GUI库,各自的特点以及相关工具的支持。
1、 MFC
大名鼎鼎的微软基础类库(Microsoft Foundation Class)。大凡学过VC++的人都应该知道这个库。虽然从技术角度讲,MFC是不大漂亮的,但是它构建于Windows API 之上,能够使程序员的工作更容易,编程效率高,减少了大量在建立 Windows 程序时必须编写的代码,同时它还提供了所有一般 C++ 编程的优点,例如继承和封装。MFC 编写的程序在各个版本的Windows操作系统上是可移植的,例如,在 Windows 3.1下编写的代码可以很容易地移植到 Windows NT 或 Windows 95 上。但是在最近发展以及官方支持上日渐势微。
2、 QT
参考网站:http://www.trolltech.com/'>http://www.trolltech.com/
Qt 是Trolltech公司的一个多平台的C++图形用户界面应用程序框架。它提供给应用程序开发者建立艺术级的图形用户界面所需的所用功能。Qt是完全面向对象的很容易扩展,并且允许真正地组件编程。自从1996年早些时候,Qt进入商业领域,它已经成为全世界范围内数千种成功的应用程序的基础。Qt也是流行的Linux桌面环境KDE 的基础,同时它还支持Windows、Macintosh、Unix/X11等多种平台。
3、WxWindows
参考网站:http://www.wxwindows.org/'>http://www.wxwindows.org/
跨平台的GUI库。因为其类层次极像MFC,所以有文章介绍从MFC到WxWindows的代码移植以实现跨平台的功能。通过多年的开发也是一个日趋完善的 GUI库,支持同样不弱于前面两个库。并且是完全开放源代码的。新近的C++ Builder X的GUI设计器就是基于这个库的。
4、Fox
开放源代码的GUI库。作者从自己亲身的开发经验中得出了一个理想的GUI库应该是什么样子的感受出发,从而开始了对这个库的开发。有兴趣的可以尝试一下。
参考网站:http://www.fox'>http://www.fox-toolkit.org/
5、 WTL
基于ATL的一个库。因为使用了大量ATL的轻量级手法,模板等技术,在代码尺寸,以及速度优化方面做得非常到位。主要面向的使用群体是开发COM轻量级供网络下载的可视化控件的开发者。
6、 GTK
参考网站:http://gtkmm.sourceforge.net/
GTK是一个大名鼎鼎的C的开源GUI库。在Linux世界中有Gnome这样的杀手应用。而GTK就是这个库的C++封装版本。