使用64位的编译工具进行编译

简介: 本文记录了使用64位的编译工具进行编译的过程

缘起

最近在编译项目的时候总是报虚拟内存不足(项目中使用了大量的模板)。一般情况下,vs会使用32位的编译工具进行编译,用64位的编译工具应该能解决类似的问题。本以为是一件挺简单的事,但是没想到遇到不少坑,本文记录了折腾的过程,希望对有类似需求的小伙伴有所帮助。

说明:本文总结的不是怎么设置 vs来生成 64位的程序,而是怎么使用 64位的编译工具来生成程序,可以生成 32位的,也可以生成 64位的。

尝试1:在vs中查找相关设置

在低版本的vs中找了很久也没有找到相关选项,看来vs只能使用默认的32位编译器进行编译。实在是不太合理啊!不过确实没找到,如果有小伙伴知道怎么设置,欢迎留言告知。

vs2019(V16.1)终于添加了相关的设置选项。

尝试2:使用msbuild

我们知道其实vs是调用msbuild进行编译链接的(msbuild会调用CL.exe进行编译,调用link.exe进行链接)。我们可以直接使用msbuild进行生成。

帮助文档

可以通过msbuild -h或者MSBuild command-line reference来查看msbuild的命令行参数。但是,貌似没有哪个参数是告诉我们如何使用64位的编译工具进行编译的。继续搜

官网指南1

在微软官方找到一篇参考文档 How to: Enable a 64-Bit, x64 hosted MSVC toolset on the command line,根据文档中的的描述,尝试过程如下:
Use-64-bit-hosted-developer-command-prompt

我们发现,编译时使用的是CL.exe,链接时使用的是link.exe。这两个文件都是子目录\bin\HostX86\x64下的。我们看下这两个程序是32位的还是64位的。
check-cl-link-bit

我们发现这个子目录下的CL.exelink.exe都是32位的。什么情况?为什么按官方文档进行操作,结果还是使用的32位的 :code_sweat:。暂时先不追究了1。继续搜

[曹景游关于MSBuild的博客]

找到了[曹景游关于MSBuild的博客],根据其中的 msbuild /p:PreferredToolArchitecture=x64 成功调用了64位的CL.exelink.exe
build-with-PreferredToolArchitecture-x64

PreferredToolArchitecture是什么?

官方参考文档

[曹景游关于MSBuild的博客]中有一个微软的官方链接(中文版),介绍了一些msbuild的内部选项,其中有关于关键字PreferredToolArchitecture的介绍。我切换到了英文版并摘录了关于PreferredToolArchitecture的介绍。如下:

PreferredToolArchitecture property

The PreferredToolArchitecture property determines whether the 32-bit or 64-bit compiler and tools are used in the build. This property does not affect the output platform architecture or configuration. By default, MSBuild uses the x86 version of the compiler and tools if this property is not set.

For example, set the PreferredToolArchitecture property to x64 to use the 64-bit compiler and tools to build your application:

msbuild myProject.vcxproj /p:PreferredToolArchitecture=x64

提示:可以把URL中关于语言的部分改成其它语言的标识即可切换到对应的语言下。中文对应着zh-cn,英文对应着en-us

其它相关资料

根据关键字PreferredToolArchitecturestackoverflow上搜到了这篇帖子how-to-make-visual-studio-use-the-native-amd64-toolchain。里面提到了vs2019(V16.1)已经支持设置编译工具了。从另外一个回复中得知,可以使用/Bv来查看编译使用的工具的全路径。

vs2019中的Preferred Build Tool Architecture设置选项

在工程文件上右键PropertyConfiguration Properties -> Advanced -> Preferred Build Tool Architecture,设置为64-bit(x64)即可使用64位的编译工具进行编译。如下图。
choose-build-tool-architecture

/Bv设置选项

在工程文件上右键 PropertiesConfiguration Properties -> C/C++ -> Command Line,添加/Bv选项。如下图。
Bv-option

输出结果

build-with-Bv

可以看到使用PreferredToolArchitecture后,确实使用了64位的编译工具。

其它尝试

  • bin\Hostx86,用bin\Hostx64的内容替换之,简单粗暴有效。:tada::tada::tada:
  • 其它说多了都是泪的尝试。:sob::sob::sob:

总结

遇到问题,关键字搜索非常重要,找对关键字,基本上成功了一半。

参考资料


  1. 关于此问题,我确实使用dnSpy进行了逆向调试,有时间会把整个过程整理出来。
相关文章
|
存储 搜索推荐 API
AppsFlyer 研究(六) 域名及用户邀请归因
AppsFlyer 研究(六) 域名及用户邀请归因
1094 0
|
7月前
|
数据采集 监控 API
告别手动埋点!Android 无侵入式数据采集方案深度解析
传统的Android应用监控方案需要开发者在代码中手动添加埋点,不仅侵入性强、工作量大,还难以维护。本文深入探讨了基于字节码插桩技术的无侵入式数据采集方案,通过Gradle插件 + AGP API + ASM的技术组合,实现对应用性能、用户行为、网络请求等全方位监控,真正做到零侵入、易集成、高稳定。
833 85
|
12月前
|
编解码 Java 开发工具
【HarmonyOS Next之旅】DevEco Studio的安装与环境配置
本教程详细介绍了使用DevEco Studio进行OpenHarmony开发的全流程,包括下载与安装、环境配置、项目准备及实用技巧。首先,以Windows环境为例,说明了DevEco Studio的运行要求、下载和安装步骤;接着,通过设置环境变量和配置SDK完成开发环境搭建;然后,讲解了项目创建、预览器和虚拟机的使用方法;最后,分享了中文插件安装和简化工程目录栏等小技巧,帮助开发者高效上手OpenHarmony开发。
1332 0
|
C++
C++11 std::lock_guard 互斥锁
C++11 std::lock_guard 互斥锁
298 0
|
存储 Prometheus 监控
监控堆外内存使用情况
监控堆外内存使用情况
920 4
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
712 2
|
JavaScript
Vue3基础(十)___toRaw___markRaw
本文介绍了Vue 3中`toRaw`和`markRaw`的用法,解释了`toRaw`用于获取`ref`和`reactive`对象的原始数据,而`markRaw`用于阻止Vue将对象转换为响应式数据。文章通过代码示例展示了这两个函数在实际开发中的应用和效果。
360 0
Vue3基础(十)___toRaw___markRaw
|
分布式计算 API 对象存储
Ray是一个开源的分布式计算框架,用于构建和扩展分布式应用。它提供了简单的API,使得开发者可以轻松地编写并行和分布式代码,而无需担心底层的复杂性。
Ray是一个开源的分布式计算框架,用于构建和扩展分布式应用。它提供了简单的API,使得开发者可以轻松地编写并行和分布式代码,而无需担心底层的复杂性。
2942 11
将文字或txt转换成GBK或者UTF8编码
将文字或txt转换成GBK或者UTF8编码
1288 1
|
机器人 数据中心
几个AC/DC电源模块的工业应用场景案例
几个AC/DC电源模块的工业应用场景案例
几个AC/DC电源模块的工业应用场景案例