九色国产,午夜在线视频,新黄色网址,九九色综合,天天做夜夜做久久做狠狠,天天躁夜夜躁狠狠躁2021a,久久不卡一区二区三区

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
Qmake VS Cmake

cmake vs qmake

  • qmake 是為 Qt 量身打造的,使用起來非常方便
  • cmake 使用上不如qmake簡單直接,但復(fù)雜換來的是強大的功能
    • 內(nèi)置的 out-of source 構(gòu)建。(目前QtCreator為qmake也默認啟用了該功能。參考:淺談 qmake 之 shadow build

    • 為各種平臺和場景提供條件編譯
    • 可處理多個可執(zhí)行文件情況,和很好配合 QtTest 工作

如何選擇?

Using CMake to Build Qt Projects 一文中說:

  • 對簡單的Qt工程,采用 qmake
  • 對復(fù)雜度超過 qmake 處理能力的,采用 cmake

盡管如此,如果簡單Qt的工程都不知道怎么用 cmake 構(gòu)建,復(fù)雜的工程,就更不知道如何使用 cmake 了。還是從簡單的學(xué)起吧

簡單的 Qt 程序

#include <QtCore/QCoreApplication>
#include <QtCore/QDebug>
int main(int argc, char** argv)
{
QCoreApplication app(argc, argv);
qDebug()<<"hello qt!";
app.exec();
}

如果不使用構(gòu)建工具,直接調(diào)用編譯器來編譯的話,只需要類似這樣的一條命令:

g++ main.cpp -Ie:\Qt\4.7.0\include -o main -Le:\Qt\4.7.0\lib -lQtCore4

指定頭文件目錄,以及需要鏈接的庫

qmake

qmake 需要一個 .pro 文件:

CONFIG += qt
QT -= gui
SOURCES += main.cpp
  • 因為我們需要 Qt的庫和頭文件,所以需要 CONFIG += qt 。

    • 這是默認項,可直接去掉該行
  • 啟用qt后,可以通過 QT -= gui 來進一步細調(diào)我們需要的模塊
    • 默認是 core gui。我們不需要gui模塊,故去掉。

cmake

cmake 需要一個 CMakeLists.txt 文件:

PROJECT(example)
FIND_PACKAGE(Qt4 REQUIRED)
SET(QT_DONT_USE_QTGUI TRUE)
INCLUDE(${QT_USE_FILE})
ADD_EXECUTABLE(example main.cpp)
TARGET_LINK_LIBRARIES(example ${QT_LIBRARIES})
  • FIND_PACKAGE 來啟用 Qt4
  • 默認使用了core 和 gui,故手動禁用 QTGUI
    • 這兩行可以直接使用 FIND_PACKAGE(Qt4 COMPONENTS QtCore REQUIRED),未指定的模塊將被禁用

  • 包含一個CMake為Qt提供的配置文件,${QT_USE_FILE}變量是一個文件名
  • 添加可執(zhí)行程序目標
  • 鏈接到 Qt 的庫

復(fù)雜一點

考慮一個常規(guī)Qt程序:

  • main.cpp
  • mainwindows.ui
  • mainwindows.h
  • mainwindows.cpp

如果手動編譯的話:

  • mainwindow.ui 需要使用 uic 預(yù)處理

uic mainwindow.ui -o ui_mainwindow.h
  • mainwindow.h 需要 moc 預(yù)處理

moc mainwindow.h -o moc_mainwindow.cpp
  • 調(diào)用編譯器進行編譯

g++ main.cpp mainwindow.cpp  moc_mainwindow.cpp -Ie:\Qt\4.7.0\include -o main  -Le:\Qt\4.7.0\lib -lQtCore4 -lQtGui4

qmake

使用 qmake 的的話,一個簡單的 pro 文件

TARGET = example
TEMPLATE = app
SOURCES += main.cpp mainwindow.cpp
HEADERS += mainwindow.h
FORMS += mainwindow.ui

HEADERS 中的文件是否需要 moc 進行預(yù)處理,qmake 運行時會根據(jù)其是否含有Q_OBJECT自動判斷。

這也是為什么 很多人添加Q_OBJECT宏后不重新運行qmake會出錯誤的原因。

cmake

看看相應(yīng)的 cmake 的 CMakeLists.txt 文件

PROJECT(example)
CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
FIND_PACKAGE(Qt4 REQUIRED)
INCLUDE(${QT_USE_FILE})
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR})
QT4_WRAP_CPP(example_MOCS mainwindow.h)
QT4_WRAP_UI(example_UIS mainwindow.ui)
ADD_EXECUTABLE(example main.cpp mainwindow.cpp ${example_MOCS})
TARGET_LINK_LIBRARIES(example ${QT_LIBRARIES})
  • 需要 moc 的文件,用 QT4_WRAP_CPP 處理
    • 生成的文件放入變量 example_MOCS 中,最后一塊鏈接到可執(zhí)行程序
  • 需要 uic 的文件,用 QT4_WRAP_UI 處理

Windows

因為windows下鏈接時分為 console 和 windows 兩個子系統(tǒng),所以windows下有些問題需要特殊處理。

用 qmake 時:

  • 默認是 windows 子系統(tǒng)
  • 可以通過 CONFIG += console 使用 console 子系統(tǒng)

用 cmake 是:

  • 默認是 console 子系統(tǒng)
  • 使用 windows 子系統(tǒng)需要

SET(QT_USE_QTMAIN TRUE)
ADD_EXECUTABLE(example WIN32 main.cpp mainwindow.cpp ${example_MOCS})

前者啟用 qtmain.lib 庫來提供windows下的 WinMain 入口函數(shù)。后者鏈接 windows 子系統(tǒng)

再復(fù)雜一點

  • main.cpp
  • mainwindows.ui
  • mainwindows.h
  • mainwindows.cpp
  • main.qrc
  • main.rc

前面已經(jīng)用到了Qt的 moc 和 uic,這次增加了資源系統(tǒng) 需要用 rcc

rcc main.qrc -o qrc_main.cpp

同時,使用了windows下的資源文件 .rc (比如給程序添加圖標)

  • MVSC 中使用 rc.exe 對 .rc 文件進行處理
  • MinGW 中使用 windres.exe 處理 .rc 文件

qmake

TARGET = example
TEMPLATE = lib
HEADERS = mainwindow.h widget.h
SOURCES = main.cpp widget.cpp mainwindow.cpp
RESOURCES = main.qrc
RC_FILE = main.rc

cmake

PROJECT(example)
CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
FIND_PACKAGE(Qt4 REQUIRED)
SET(QT_USE_QTMAIN TRUE)
INCLUDE(${QT_USE_FILE})
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR})

if(MINGW)
set(CMAKE_RC_COMPILER_INIT windres)
ENABLE_LANGUAGE(RC)
SET(CMAKE_RC_COMPILE_OBJECT
"<CMAKE_RC_COMPILER> <FLAGS> -O coff <DEFINES> -i <SOURCE> -o <OBJECT>")
endif(MINGW)

SET(example_SRCS main.cpp mainwindow.cpp widget.cpp res/main.rc)
SET(example_MOC_SRCS mainwindow.h widget.h)
QT4_WRAP_CPP(example_MOCS ${example_MOC_SRCS})
QT4_ADD_RESOURCES(example_RCC_SRCS main.qrc)
SET(example_SRCS ${example_SRCS} ${example_MOCS} ${example_RCC_SRCS})

ADD_EXECUTABLE(example WIN32 main.cpp mainwindow.cpp ${example_SRCS})
TARGET_LINK_LIBRARIES(example ${QT_LIBRARIES})
  • 對Qt的資源文件,使用 QT4_ADD_RESOURCES 來調(diào)用rcc進行預(yù)處理
  • 對 Windows 資源文件,直接和源文件一樣,添加到列表中即可。只是:
    • MinGW 下僅僅這么做還不行,上面的 MinGW 塊用來修復(fù)這個問題

Debug 與 Release

qmake

使用 qmake 時,可以在 pro 文件內(nèi)分別為兩種模式設(shè)置不同的選項。

使用時,可以直接 make release 或 make debug 來編譯不同的版本

cmake

不同于 qmake,由于 cmake 采用 out-of-source 方式。故:

  • 建立debug release兩目錄,分別在其中執(zhí)行cmake -DCMAKE_BUILD_TYPE=Debug(或Release)
  • 需要編譯不同版本時進入不同目錄執(zhí)行make

對生成 msvc 工程的情況, CMAKE_BUILD_TYPE 不起作用。生成工程后使用IDE自帶的模式選擇。

參考

trackback: http://hi.baidu.com/cyclone/blog/item/41651d95d86028187bf480eb.html

本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
CMake 備忘清單
QtCreator之cmake項目創(chuàng)建編譯流程
在Windows中安裝配置Qt
Qt
Qt經(jīng)典出錯信息
QMake介紹以及使用
更多類似文章 >>
生活服務(wù)
熱點新聞
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服