qmake以及makefile总结

Qmake  编写pro常用参数


TEMPLATE = subdirs           #编译类型-子目录

CONFIG = ordered             #编译次序-顺序编译

SUBDIRS += ParaIO            #子目录名
在程序顶层执行" qmake –r ",在每个子目录生产Makefile文件

MOC_DIR=./moc

  指定moc文件存放路径


OBJECTS_DIR=./obj

  指定.o 文件路径


QMAKE_CXXFLAGS += -g

  g++ 编译添加 –g 选项,增加调试信息


QMAKE_CFLAGS += -g

          gcc 编译添加 –g 选项,增加调试信息

参数 “-o”生成指定Makefile的名字
Eg.
qmake seisFlwo.pro -o Makefile_pro –r
根据pro文件在各个子目录生成Makefile,命名为      Makefile_pro
make -f Makefile_pro
编译seisFlwo.pro内所包含的所有的Makefile

*******************************************************************************************************

手动编写makefile时,应从系统层面考虑,编译时务必自顶向下编译各个子目录,禁止将各个模块分别编译,手动拷贝执行文件

 

使用参数 “-C”,eg.

     make –C  tools        # 编译子目录tools

     make  clean–C  tools  #清除子目录tools


  . PHONY

  显式请求时执行命令的名字, eg.

.PHONY all:                             #编译时执行命令,缺省为all

all:   tool                                   #命令名所包含子模块


.PHONY clean:

clean:   tool_clean



tool_clean:                               #子模块的具体编译内容

        make clean-C tools

tool:

        make -Ctools

参数 "-j"

  多核编译,适用于多核处理器,

  查看cpu信息确定核数,"cat/proc/cpuinfo"

  运行命令  make  -j  核数+1 , 加快编译速度


参数 "-s", 不打印编译信息


参数  "-f ",编译 指定makefile,默认编译Makefile和makefile文件,eg,  make  -f  mymakefile


*******************************************************************************************************
环境变量的使用

编程原则

 

 禁止使用绝对路径

 尽量不用相对路径

 使用环境变量,提高代码可移植性


环境变量    PROJECTDIR
        makefile中的获取方式$(PROJECTDIR)

  qmake的pro中获取方式$$(PROJECTDIR)

  cmake中的获取方式 $ENV{PROJECTDIR}

  c程序中获取方式getenv("PROJECTDIR")

  shell脚本中获取方式 ${BASE_PATH}

  python程序中获取方式

  import os

  os.getenv("PROJECTDIR")

参考:http://blog.chinaunix.net/uid-17271829-id-5088010.html

QT_QPA_DEFAULT_PLATFORM = linuxfb

QMAKE_CFLAGS_RELEASE   += -O2 -march=armv7-a     #cortex-A8
QMAKE_CXXFLAGS_RELEASE += -O2 -march=armv7-a


include(../common/linux.conf)
include(../common/gcc-base-unix.conf)
include(../common/g++-unix.conf)


modifications to g++.conf
QMAKE_CC                = arm-linux-gcc     #此处需要根据开发者电脑使用的具体交叉编译器的配置而定
QMAKE_CXX               = arm-linux-g++
QMAKE_LINK              = arm-linux-g++

QMAKE_LINK_SHLIB        = arm-linux-g++

参考:http://blog.csdn.net/clmngu/article/details/51207222


测试代码:

  1. int main(void)  
  2. {  
  3.     double counter;  
  4.     double result;  
  5.     double temp;  
  6.   
  7.     for (counter = 0; counter < 2000.0 * 2000.0 * 2000.0 /20.0 + 2200; counter += (5-1)/4)  
  8.     {  
  9.         temp = counter / 1979;  
  10.         result = counter;  
  11.     }  
  12.     printf("Result is %lf\\n", result);  
  13.     return 0;  


  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 Windows 下,你可以使用 Qt 自带的 qmake 工具来生成 Makefile 文件。以下是使用 qmake 生成 Makefile 文件的步骤: 1. 安装 Qt:你可以从 Qt 官网上下载 Qt 安装包,然后按照提示进行安装。安装完成后,你需要将 Qt 的 bin 目录添加到系统环境变量中,例如: ``` C:\Qt\5.15.2\msvc2019_64\bin ``` 2. 创建 .pro 文件:在你的项目根目录下创建一个名为 `myproject.pro` 的文件,该文件包含了 qmake 的配置信息。你需要根据你的项目需求来编写 myproject.pro 文件,例如: ``` TEMPLATE = app TARGET = myapp SOURCES += main.cpp ``` 上述配置将会生成一个名为 `myapp` 的可执行文件,该可执行文件的源代码位于 `main.cpp` 文件中。 3. 打开命令行窗口:在 Windows 中,你可以按下 `Win+R` 快捷键,然后输入 `cmd` 命令打开命令行窗口。 4. 进入项目目录:使用 `cd` 命令进入你的项目目录,例如: ``` cd C:\myproject ``` 5. 生成 Makefile 文件:使用 `qmake` 命令来生成 Makefile 文件,例如: ``` qmake myproject.pro -spec win32-g++ -o Makefile ``` 上述命令中,`myproject.pro` 是你的项目文件名,`-spec win32-g++` 参数用于指定编译器,`-o Makefile` 参数用于指定输出文件名。 6. 编译项目:使用 `make` 命令来编译项目,例如: ``` make ``` 这将会编译项目并生成可执行文件。 希望这些信息对你有所帮助。如果你还有其他的问题或疑问,请告诉我,我会尽力帮助你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI算法网奇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值