Qt血的教训/细数Qt开发的各种坑/又爱又恨/欢迎围观留言评论

一、吐槽总结

搞Qt开发十几年了,最初从Qt4.6开始,一直追新到现在的6.7版本,中间经历过无数的血的教训,简直是又爱又恨。其实Qt挺好的,但是还是要忍不住吐槽一下,本人还是希望Qt发展的越来越好,这样我的饭碗就能保住了。

1. 版本众多

  • Qt的版本多到你数都数不清,多到你开始怀疑人生。
  • Qt版本从4.6开始到6.8,光这一阶段就无数版本。
  • 编译器从msvc编译器到mingw编译器再到gcc编译器等。
  • 位数从32位到64位。
  • 操作系统有windows、linux、mac、android、ios等系统,还有各种嵌入式linux,现在又多了国产linux。
  • msvc版本还必须安装对应的 vs2005、vs2008、vs2010、vs2013、vs015、vs2017、vs2019、vs2022等。
  • mingw版本必须安装不小于某个版本号的mingw编译器。
  • 很多人一看官网的下载链接,就蒙圈了,到底应该选择哪一个进行下载开发呢?对初学者真不友好。
  • 为了能够做到开发跨平台应用,不得不安装多块硬盘和多个操作系统,虚拟机的坑使得必须安装真机环境才能测试出真实效果。
  • 最基本的你必须安装windows XP,WIN7 32位 64位,WIN10 32位 64位,ubuntu 14.04 15.04 16.04。
  • 嵌入式开发还得搞各种交叉编译环境,尤其记忆最深刻的是在2012年搭建交叉编译环境花了3周时间。
  • 搞Qt安卓开发最好用干净的系统, 本人试过N次,在原有的安装了很多东西的电脑上搭建Qt android开发环境死活不成功,必须全新安装的操作系统才可以,所以单独搞了一块硬盘用来Qt开发android。
  • 本人就在四块硬盘上安装了十几个操作系统,安装了至少30个Qt开发环境,我的乖乖。
  • 大概从2020年开始,Qt飙版本的速度,超过了各位工资的涨幅速度。

2. 各种乱码

  • Qt各种乱码问题,困扰Qter一生,尤其是Qt4时代;
  • 有时候解决了界面乱码,输出又出乱码了;
  • 解决了输出乱码,界面又乱码了;
  • 界面不乱码了,结果qdebug打印又乱码;
  • mingw不乱码了,结果msvc又乱码,关键是程序一模一样。
  • 乱码提示只有上帝能看懂,都是些火星文,非常坑爹;
  • 声明下:这不只是Qt的问题,这是IT界的问题,什么utf-8带BOM,什么MSVC默认是GBK编码,什么回车换行符\r\n。
  • 幸运的是,大概从Qt5以后,乱码问题少很多。

3. 接口变动

  • Qt最近十几年大概有3个大版本,分别是Qt4、Qt5、Qt6,按照目前飙版本的速度,预计不到2年还有个Qt7出生。
  • 版本接口变动最大的是Qt4到Qt5,其次是Qt5到Qt6,直觉告诉我,Qt6和Qt7接口变动不会很大,应该很小。
  • 接口变动是避免不了的事情,但是同一个函数的命名变来变去,这就有点接受不了。
  • Qt内置方法的变动,让一些喜欢追逐新版本Qt开发环境的Qter们抓耳挠腮,一下子toAscii,一下子就没了,一下子QSound在QtGUI,一下子移到了multimedia中。打印模块也是移来移去,其他的就不细数了。
  • 浏览器内核变来变去,以前webkit好好的,后面居然抛弃了,我勒个去,始乱终弃啊!你让以前依赖webkit内核的项目怎么换啊,改来改去的。
  • 大概从Qt5.6版本开始集成的是webengine谷歌内核,最起码有,也能接受,但是这逼不支持mingw编译器。而Qt默认自带编译器就是mingw,意味着默认就不能用浏览器控件。这下搞得,哎。
  • 高版本开发环境居然不兼容低版本,这可是犯了大忌啊。
  • 每一个巨大版本的变动,意味着学习成本上升。
  • 网上大量的Qt4和Qt5时代的代码,让很多Qt4时代的代码不能正常在Qt5环境中编译,导致网上各种初学者下载到的Qt4代码编译没有一个通过的人丧失信心,甚至又开始怀疑人生,网上都是骗人的又一次浮现脑海。
  • 对标c#和java,基本上都是很容易的升级大版本,因为接口几乎就是一致的。

4. 打包发布

  • Qt发布也困扰了不少的初学者,尤其是高达几十兆的运行库文件,更是崩溃至极。
  • 不是提示缺少某个文件,就是那边少了数据库插件,甚至蹦蹦蹦的弹框。
  • 最可恨可气无奈的是,明明某些电脑可以正常运行,某些电脑死活跑不成功。
  • 后面出了个deployqt工具要方便很多,以前没有这个工具的时候,简易一头雾水。
  • 有错误提示还好,关键是很多时候直接无法运行,啥提示都没有,只能慢慢查。
  • 对标c#程序,只需要安装个.NET框架就行,非常方便。

5. 兼容性

  • Qt就是因为兼容性好,所以最后做到了兼容性差。
  • 总的来说其实就是基础功能兼容性好,平台相关的一些特性兼容性差。
  • 最大吐槽就属于高分屏缩放的兼容性问题,到现在Qt6基本还没解决,看QtCreator本身的兼容性就知道。
  • qml兼容性巨坑,各种的不稳定,直到5.7版本开始才好点,很多老式电脑无法正常运行。
  • 在Qt6以前,那个qml设计器更是惨不忍睹无法直视,字体细小难看,还必须放大镜才能看清是什么,既然做了就做好点,不然怎么让开发者用呢?
  • qml开发的商业产品或者作品,到现在也没有看到几个好的,移动端的更加稀少。没有看到一个让人惊艳的作品。

6. 网友补充

  • 有时候debug正常,release又崩溃。可能是路径问题?
  • 集成开发环境QtCreator中文翻译不全,一会中文一会英文,看起来非常别扭。
  • 长期用Qt会产生严重的依赖症,什么都Qt给你封装好了。长此以往,变成Qt程序员而非C++程序员。
  • qml组件中很多控件是半成品,嵌套组件下Qml设计器很难用。
  • QtCreator在debug调试非常鸡肋,而且容易崩溃。

二、开源地址

  1. 国内站点:https://gitee.com/feiyangqingyun
  2. 国际站点:https://github.com/feiyangqingyun
  3. 个人作品:https://blog.csdn.net/feiyangqingyun/article/details/97565652
  4. 视频主页:https://space.bilibili.com/687803542


posted @ 2024-04-07 10:48  飞扬青云  阅读(72)  评论(0编辑  收藏  举报