从Qt 5移植到Qt 6的过程一直很容易。在Qt 6的整个开发过程中,一直有意识地努力保持与Qt 5的尽可能多的源兼容性。尽管如此,移植仍需要一些努力。这篇简短的文章总结了移植到Qt 6时所需的一些步骤。
工具推荐:
- QtitanRibbon: 遵循Microsoft Ribbon UI Paradigm for Qt技术的Ribbon UI组件,致力于为Windows、Linux和Mac OS X提供功能完整的Ribbon组件。
- QtitanChart :是一个C ++库,代表一组控件,这些控件使您可以快速地为应用程序提供漂亮而丰富的图表。并且支持所有主要的桌面操作系
在Qt 5中,有些类别已经有现有的替代品,并且某些类别在Qt 6开发阶段得到了继任者。因此,能够同时使用旧的和新的Qt版本编译代码可能很有意义。这样可以确保将不使用任何版本的代码进行编译的工作量减至最少,从而使您的应用程序或库可以继续与Qt 5和Qt 6一起工作。另一个优点是,现有的单元测试对于大多数版本都可以继续工作。移植的持续时间以及移植代码所导致的回归与Qt 6中引入的错误很容易区分开。
种类
下表列出了在Qt 6中已删除但为了便于移植而保留在Qt5Compat中的类。它还包含将在Qt6中的新代码中使用的类。
Qt 5类Qt 6更换QLinkedList
std :: list *QRegExpQRegularExpressionQStringRefQStringViewQXmlSimpleReaderQXmlStreamReaderQTextCodecQStringConverterQTextEncoderQStringEncoderQTextDecoderQStringDecoder
*如果不需要链接列表的引用稳定性,则也可以考虑使用QList。
调整构建系统
如果要继续使用上述Qt 5类,首先需要调整您的构建系统以链接到新的Qt5Compat模块。对于qmake构建系统,将以下行添加到.pro文件中:
QT += core5compat
如果您已经将应用程序或库移植到了cmake构建系统,请将以下内容添加到您的 CMakeList.txt:
PUBLIC_LIBRARIES
Qt::Core5Compat
修复包括
除了显然需要进行的构建系统更改外,您可能还需要修复前面提到的类的包含。您的实际代码可能如下所示:
#include <QtCore / QRegExp>
需要针对新的Qt5Compat模块进行更新:
#include <QtCore5Compat / QRegExp>
或使用更加简单和可移植的版本:
#include <QRegExp>
好了这就是今天的内容了,如果今天的文章未解决你的需求,可点击点击文末“了解更多”获取更多免费教程。不要忘了在评论与我分享您的想法和建议。最后一句:记得关注我哦!
本文暂时没有评论,来添加一个吧(●'◡'●)