百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

C++是否真的适合做GUI界面?MFC真的过时了吗?

liebian365 2024-10-15 13:46 25 浏览 0 评论

#头条创作挑战赛#

1、前言

??这几天在论坛看到一个有趣的问题:新人入职公司做C++开发,发现公司用的界面GUI还是微软古老的MFC框架,想问大家MFC是不是已经过时了?是否还有深入学习的必要? 其实,个人觉得在讨论这个问题之前还有一个更宽泛的问题:C++语言本身是否适合做GUI界面?

2、C++是否适合做GUI?

??先说结论:根据多数开发C++的人来说,单纯做界面GUI的话,C++本身其实并不太适合写GUI。因为C++本身不具备反射和自省,类体系结构非常的静态,且抽象能力有限,而界面GUI本身是个相当动态的东西,所以最基础的C++并不适合用来写GUI,硬写的话最后的程序会非常的冗长和啰唆的。

所以聪明的GUI库通常会用一些技巧绕过这个问题:

  1. 大量宏技巧来保存meta信息,如MFC、wxWigdet。
  2. 用额外的source transformer来提供反射和动态messaging能力,如Qt。
  3. 在C++基础上实现一个Domain Specific Language,包括Qt以及各种DirectUI方案。

??严格意义上讲,后两种手段都属于DSL方法,所以已经不能算是纯粹的C++开发GUI了。其实最适合写native GUI的语言是Objective-C语言,即便抛弃Cocoa库来讲,单纯的论语言能力也是如此,可惜的是它针对IOS系统,并不能支持跨平台。

3、流行的C++界面GUI库

??图形用户界面(Graphical User Interface,简称 GUI),下面介绍一下C++常用的GUI开发框架:

(1) QT

Qt 是Qt Company开发的跨平台C++图形用户界面应用程序开发框架,目前使用很广泛;

支持平台:Windows、Linux、MacOS等等;

网址:https://www.qt.io;

(2) MFC

Windows下的GUI库,使用比较广泛;

支持平台:Windows;

网址:https://www.microsoft.com/zh-cn/;

(3) wxWidgets

wxWidgets是一个C ++库,开发人员可以使用它为Windows,Linux,MacOS和其他平台创建应用程序;

支持平台:Windows、Linux、MacOS;

网址:https://wxwidgets.org

(4) gtkmm

gtkmm 是流行的图形界面库 GTK+的官方 C++ 接口;

支持平台:Windows、Linux、MacOS;

网址:https://www.gtkmm.org;

其他界面库还有:

imgui (https://github.com/ocornut/imgui)

duilib (https://github.com/duilib/duilib)

xcgui (http://www.xcgui.com/)

GuiLite (https://gitee.com/idea4good/GuiLite)

3、为什么这么多流行的GUI库都用C++实现?

??至于为什么这么多流行的GUI库都用C++实现,很多原因不是在语言本身的能力上,几个可能的原因是:

1)GUI是个基础构件,用C/C++这种较基础和非常流行的语言来实现的话,可以让这个库被更多的其它语言所使用。

2)原生性。很多实际应用需求可能不允许类似C#语言这种附带一个编译运行时的东西,或者带一个臃肿的Webkit,尤其对互联网客户端来讲,需要发布的东西越小越轻量越好,所以这些公司的客户端基本上都是自己造一个轻量级的DirectUI,只满足自己的需求即可,而不用考虑推广性和普遍性。

3)保留了在性能和抽象之间做权衡的能力。如果采用了HTML/CSS/JS,那么当你需要高性能实时渲染时,可能无法实现。做为一个库来讲的话,用户的应用场景千变万化,必须要为这些可能性保留相关的能力。

??总得来说用C++写GUI需要付出更多的努力,但回报也更高,前提是有一个或轮一个靠谱的DSL。事实上HTML/CSS/JS也可以看作是一个DSL,运行在C++写成的解释器(浏览器)上。

4、MFC是否已经过时?

??Microsoft Foundation Classes,是微软公司提供的类库,以 C++类的形式封装了Windows API,也是一个应用程序框架,用以减少应用程序开发人员的工作量。但令人遗憾的是MFC 在很多年前就已经停止更新了,微软官方现在也是在主推自家的 .net 技术,虽然 MFC 也被保留了下来,但更多的是为了一些旧的产品的维护开发使用,比如一些大公司的老旧产品是用MFC开发的,多年积累下来,想换一种框架重写的话,可能工作量无法估计,另外很可能会出现大量未知的bug,因此仍旧采用当下的MFC来维护不失为一种最稳妥的方式。

5、界面开发趋势——混合开发

??单纯做界面的话,那么最适合的可能是HTML/CSS/JS,理论上来讲它是把结构描述(HTML)、样式描述(CSS)和动态计算(JS)划分的最好的,并且高度标准化。假如你的GUI程序中不存在高性能实时渲染的话(如毫秒级更新的图表、或嵌入OpenGL/D3D窗口),那么配合前端之类的MVC库,软件操作手感和响应几乎可以达到和native程序一样,并且写起来比C++轻松和简洁很多,并且界面的美观性也可以得到保证。

??对于不那么追求软件包大小以及运行效率要求非顶尖的软件,其实目前比较流行的是C++混合开发,大体就是利用html+js来编写界面,然后利用控件方式嵌入C++中,后台的程序处理用C++来实现,这样也能保证客户端和web端的界面统一性,例如Qt提供的QWebengine控件,或者自己编译谷歌浏览器内核CEF,然后与Qt结合成QCefView使用,这是目前个人了解的较为流行的混合开发方式。

相关推荐

“版本末期”了?下周平衡补丁!国服最强5套牌!上分首选

明天,酒馆战棋就将迎来大更新,也聊了很多天战棋相关的内容了,趁此机会,给兄弟们穿插一篇构筑模式的卡组推荐!老规矩,我们先来看10职业胜率。目前10职业胜率排名与一周前基本类似,没有太多的变化。平衡补丁...

VS2017 C++ 程序报错“error C2065:“M_PI”: 未声明的标识符"

首先,程序中头文件的选择,要选择头文件,在文件中是没有对M_PI的定义的。选择:项目——>”XXX属性"——>配置属性——>C/C++——>预处理器——>预处理器定义,...

东营交警实名曝光一批酒驾人员名单 88人受处罚

齐鲁网·闪电新闻5月24日讯酒后驾驶是对自己和他人生命安全极不负责的行为,为守护大家的平安出行路,东营交警一直将酒驾作为重点打击对象。5月23日,东营交警公布最新一批饮酒、醉酒名单。对以下驾驶人醉酒...

Qt界面——搭配QCustomPlot(qt platform)

这是我第一个使用QCustomPlot控件的上位机,通过串口精确的5ms发送一次数据,再将读取的数据绘制到图表中。界面方面,尝试卡片式设计,外加QSS简单的配了个色。QCustomPlot官网:Qt...

大话西游2分享赢取种族坐骑手办!PK趣闻录由你书写

老友相聚,仗剑江湖!《大话西游2》2021全民PK季4月激燃打响,各PK玩法鏖战齐开,零门槛参与热情高涨。PK季期间,不仅各种玩法奖励丰厚,参与PK趣闻录活动,投稿自己在PK季遇到的趣事,还有机会带走...

测试谷歌VS Code AI 编程插件 Gemini Code Assist

用ClaudeSonnet3.7的天气测试编码,让谷歌VSCodeAI编程插件GeminiCodeAssist自动编程。生成的文件在浏览器中的效果如下:(附源代码)VSCode...

顾爷想知道第4.5期 国服便利性到底需优化啥?

前段时间DNF国服推出了名为“阿拉德B计划”的系列改版计划,截至目前我们已经看到了两项实装。不过关于便利性上,国服似乎还有很多路要走。自从顾爷回归DNF以来,几乎每天都在跟我抱怨关于DNF里面各种各样...

掌握Visual Studio项目配置【基础篇】

1.前言VisualStudio是Windows上最常用的C++集成开发环境之一,简称VS。VS功能十分强大,对应的,其配置系统较为复杂。不管是对于初学者还是有一定开发经验的开发者来说,捋清楚VS...

还嫌LED驱动设计套路深?那就来看看这篇文章吧

随着LED在各个领域的不同应用需求,LED驱动电路也在不断进步和发展。本文从LED的特性入手,推导出适合LED的电源驱动类型,再进一步介绍各类LED驱动设计。设计必读:LED四个关键特性特性一:非线...

Visual Studio Community 2022(VS2022)安装图文方法

直接上步骤:1,首先可以下载安装一个VisualStudio安装器,叫做VisualStudioinstaller。这个安装文件很小,很快就安装完成了。2,打开VisualStudioins...

Qt添加MSVC构建套件的方法(qt添加c++11)

前言有些时候,在Windows下因为某些需求需要使用MSVC编译器对程序进行编译,假设我们安装Qt的时候又只是安装了MingW构建套件,那么此时我们该如何给现有的Qt添加一个MSVC构建套件呢?本文以...

Qt为什么站稳c++GUI的top1(qt c)

为什么现在QT越来越成为c++界面编程的第一选择,从事QT编程多年,在这之前做C++界面都是基于MFC。当时为什么会从MFC转到QT?主要原因是MFC开发界面想做得好看一些十分困难,引用第三方基于MF...

qt开发IDE应该选择VS还是qt creator

如果一个公司选择了qt来开发自己的产品,在面临IDE的选择时会出现vs或者qtcreator,选择qt的IDE需要结合产品需求、部署平台、项目定位、程序猿本身和公司战略,因为大的软件产品需要明确IDE...

Qt 5.14.2超详细安装教程,不会来打我

Qt简介Qt(官方发音[kju:t],音同cute)是一个跨平台的C++开库,主要用来开发图形用户界面(GraphicalUserInterface,GUI)程序。Qt是纯C++开...

Cygwin配置与使用(四)——VI字体和颜色的配置

简介:VI的操作模式,基本上VI可以分为三种状态,分别是命令模式(commandmode)、插入模式(Insertmode)和底行模式(lastlinemode),各模式的功能区分如下:1)...

取消回复欢迎 发表评论: