Qt 5.7.1/5.8.0/5.9.0 在 msvc2015/mingw32 方式下的静态编译过程

本文详细介绍了Qt 5.7.1至5.9.0版本的静态编译过程,包括准备工作、配置Makefile文件、编译Qt库、配置Qt库及配置Qt Creator等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

版权声明:本文为博主原创文章,未经博主允许不得转载。

目录(?)[+]

注:Qt5.9.0的操作过程除configure参数之外与5.8.0基本一致(mingw版5.9.0的qmake.conf文件中QMAKE_LFLAGS            = -static这一行需要手动添加)。

准备工作:

1. 在Qt官网下载Qt库的源码。

 

            Qt 5.7.1: https://download.qt.io/archive/qt/5.7/5.7.1/single/

            Qt 5.8.0: https://download.qt.io/archive/qt/5.8/5.8.0/single/

         

2. 下载并安装Pythonhttps://www.python.org/downloads/

3. 下载并安装Perl。https://www.perl.org/

4. 下载并安装Ruby。http://www.ruby-lang.org/en/downloads/

 

注意:① 下载Ruby时选择安装包版本。

            ② 安装python,Perl,Ruby时要注意勾选添加环境变量到系统。

            ③ 检测三个环境是否安装好,打开cmd窗口:

                Python的检测:Python

                Perl的检测:Perl -v

                Ruby的检测:Ruby -v

 

第一步:配置Qt的Makefile文件

1. 将下载的qt源码解压后,放在硬盘的根目录。例如:C:\qt_5.7.1_src

 

注:如果qt源码目录的路径比较长会导致编译qtimageformats时出现 无法打开编译器生成的文件“”:Invalid argument的错误,所以放在根目录下,尽量减少路径长度。

 

2. msvc版本:

 

            修改源码中\qtbase\mkspecs\common\msvc-desktop.conf文件,

 

           QMAKE_CFLAGS_RELEASE    = -O2 -MD
           QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -MD -Zi
           QMAKE_CFLAGS_DEBUG      = -Zi -MDd

 

           改为:

 

           QMAKE_CFLAGS_RELEASE    = -O2 -MT
           QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -MT -Zi
           QMAKE_CFLAGS_DEBUG      = -Zi -MTd

 

mingw版本:

            修改源码中\qtbase\mkspecs\win32-g++\qmake.conf文件,

 

            QMAKE_LFLAGS            = 
            QMAKE_LFLAGS_EXCEPTIONS_ON = -mthreads
            QMAKE_LFLAGS_EXCEPTIONS_OFF =
            QMAKE_LFLAGS_RELEASE    = -Wl,-s
            QMAKE_LFLAGS_DEBUG      =
            QMAKE_LFLAGS_CONSOLE    = -Wl,-subsystem,console
            QMAKE_LFLAGS_WINDOWS    = -Wl,-subsystem,windows
            QMAKE_LFLAGS_DLL        = -shared

 

            改为:

 

             QMAKE_LFLAGS            = -static
            QMAKE_LFLAGS_EXCEPTIONS_ON = -mthreads
            QMAKE_LFLAGS_EXCEPTIONS_OFF =
            QMAKE_LFLAGS_RELEASE    = -Wl,-s
            QMAKE_LFLAGS_DEBUG      =
            QMAKE_LFLAGS_CONSOLE    = -Wl,-subsystem,console
            QMAKE_LFLAGS_WINDOWS    = -Wl,-subsystem,windows
            QMAKE_LFLAGS_DLL        = -static

 

注:Qt 5.8.0中有一个cpp文件(qtbase\src\plugins\generic\tuiotouch\qtuiohandler.cpp)包含了非ASCII字符,需要用notepad++另存一个带BOM的UTF-8编码文件,替换原文件。

 

3. msvc版:

            打开VS自带的命令提示窗口:

            

 

            注:如果是编译x64的Qt,则需要打开VS2015 x64 本机工具命令提示符:

            

 

mingw版:

           打开mingw32版Qt附带的命令行工具:

           

 

4. 通过cd命令进入qt源码目录:cd C:\qt_5.7.1_src

 

注:如果源码不在系统盘,则需要先用“盘符:”命令进入所在分区,如"D:"、"cd D:\qt_5.7.1_src"就进入了D盘的源码目录。

 

5. 输入Configure命令:

 

Qt 5.7.1:

 

[sql] view plain copy

  1. configure -confirm-license -opensource -debug-and-release -static -force-debug-info -prefix "D:\msvc2015_static" -qt-sql-sqlite -qt-sql-odbc -plugin-sql-sqlite -plugin-sql-odbc -qt-zlib -qt-libpng -qt-libjpeg -opengl desktop -qt-freetype -no-qml-debug -no-angle -nomake tests -nomake examples  

 

Qt 5.8.0:

 

[plain] view plain copy

  1. configure -confirm-license -opensource -debug-and-release -static -force-debug-info -prefix "E:\msvc2015_static" -qt-sqlite -qt-pcre -qt-zlib -qt-libpng -qt-libjpeg -opengl desktop -qt-freetype -nomake tests -nomake examples  

 

Qt 5.9.0(msvc版)

 

[plain] view plain copy

  1. configure -confirm-license -opensource -platform win32-msvc -debug-and-release -static -static-runtime -force-debug-info -prefix "E:\msvc2015_static" -qt-sqlite -qt-pcre -qt-zlib -qt-libpng -qt-libjpeg -opengl desktop -qt-freetype -nomake tests -no-compile-examples -nomake examples  


Qt 5.9.0(mingw版)

 

 

[plain] view plain copy

  1. configure -confirm-license -opensource -platform win32-g++ -debug-and-release -static -static-runtime -force-debug-info -prefix "E:\mingw53_32_static" -qt-sqlite -qt-pcre -qt-zlib -qt-libpng -qt-libjpeg -opengl desktop -qt-freetype -nomake tests -no-compile-examples -nomake examples  

 

 

 

注:-prefix后跟的是编译完成后的安装目录,替换成自己的目录即可。

 

msvc版:

            执行完成后会提示nmake:

            

mingw版:

            

 

 

第二步:编译Qt库

1.msvc版: 

            执行nmake命令:

            

2.mingw版:

            执行mingw32-make命令:

            

 

注:此步大约会执行2~3小时。

 

2. 执行结束后没有报错说明编译成功,接下来安装到指定目录。

msvc版:执行nmake install命令。

mingw版:执行mingw32-make install。

 

注:此步大约执行10~20分钟。

3. 执行完成后没有报错说明安装成功,D:\msvc2015_static文件夹中即为最终的qt库。

 

第三步:配置Qt库

1. qt.conf文件指明qt库目录的前缀、文档目录和示例目录,如果将安装目录挪到别处则需要修改或新建。在bin文件夹下新建qt.conf文件,并输入以下内容:

 

[plain] view plain copy

  1. [Paths]  
  2. Documentation=C:/Qt/Qt5.7.1/Docs/Qt-5.7  
  3. Examples=C:/Qt/Qt5.7.1/Examples/Qt-5.7  
  4. Prefix=D:/msvc2015_static  


注:① 文档和示例目录此处使用了官方的msvc2015动态编译版安装包中的目录,也可以删掉这两项。Prefix是存放Qt库的目录。

 

        ② 建议把静态的Qt库和动态的Qt库放在同一目录,这样可以直接复制动态Qt库目录下的qt.conf文件,或输入以下内容:

 

[plain] view plain copy

  1. [Paths]  
  2. Documentation=../../Docs/Qt-5.7  
  3. Examples=../../Examples/Qt-5.7  
  4. Prefix=..  

 

2. 复制动态库中的bin/qmlscene.exe到静态库的bin文件夹中。否则在Qt Creator中添加Qt库时会报qmlscene未安装的错误。

 

3. 此步是Qt 5.7.1的msvc版需要执行的步骤:从源码目录中复制pdb文件到安装目录的lib文件夹。

将下面文本复制到批处理文件中,然后放在lib文件夹中执行:

 

[plain] view plain copy

  1. for /r C:\qt_5.7.1_src %%a in (*.pdb) do if /i "%%~xa"==".pdb" copy "%%~a"  
  2.   
  3. pause  

 

有些pdb文件不是放在lib文件夹的,此时需要按照pdb的名字进行搜索,将同名的pdb和lib放在一起。

最后删除批处理文件。

 

注:① 如果不执行此步,编译时会有“未找到PDB文件”的警告,且调试时无法跟踪到Qt的源码。

 

4. 从动态链接版的Qt库的bin文件夹中复制Qt5Core.dll到静态链接版的lib文件夹中。

 

注:① 如果不执行此步,在Creator的Qt Version中将会显示“x86-windows-unknown-pe-32bit”。

第四步:配置Qt Creator

1. 添加Qt Versions:

 

2. 新建一个构建套件,Qt版本选择刚添加的静态版,其他选项与动态版相同即可。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值