首页| 论坛| 消息
主题:Qt血的教训/细数Qt开发的各种坑/又爱又恨/欢迎围观留言评论
liudianwu发表于 2024-04-07 10:45
一、吐槽总结
搞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++程序员。qm

浏览大图

浏览大图
下一页 (1/2)
回帖(2):
2楼:深有同感啊。
尤其是网友补充的,debug正常,release崩溃,Creator下的debug经常崩溃
1楼:这广告大的,楼主给论坛赞助下吧,

全部回帖(2)»
最新回帖
收藏本帖
发新帖