VS宏与环境变量不一致问题

VS宏路径与环境变量不一致问题

1. 缘起

今天遇到一个奇怪的问题,有一个现有的项目,正常时用msbuild编译,项目下有csproj文件。平时直接用vs打开csproj就可以了,但是重新配置了环境之后,居然打不开了。提示如下:
在这里插入图片描述
由于最后的结果比较无语,过程也充满了各种曲折,因此把排查过程记录下来,以供以后参考。

2. 直接原因

这是怎么回事呢?用记事本打开csproj文件看了一下,里面有一行

<Import Project="$(XXXRootDir)root.settings" />

正常的这个$(XXXRootDir)应该是C:\root\XXX\可是这个提示里却提示C:\root\xxx\ \m \root.setting找不到,怎么会多出来一个\m呢?
于是怀疑是环境变量的问题,
打开cmd,输入

>echo %XXXRootDir%

输出的是

C:\root\xxx\ 

这就奇怪了,怎么能VS里的macro与环境变量里不一致呢?

3.深挖原因

下一步从两个方面来查,一个是从vs里面去查这个macro的值,另一个是再次去查系统环境变量。

3.1 C#工程中的macro值

要用vs查macro值,就要先打开工程才行,于是手工把csproj中的$(XXXRootDir)替换为了绝对路径C:\root\XXX\,现在能打开工程了,找到工程的属性,找到Build Events 点击Edit Pre-build, 点击Macros>>就可以查看VS中的Macros了。
在这里插入图片描述

但是很不幸,这里面并没有我要找的$(XXXRootDir), 只有VS的内部macro

3.2 C++工程中的Macros

既然C#的工程没有找到系统环境变量的Macro, 那么用C++的工程可以吗?
于是新建了一个C++工程,找到属性,通用, 输出路径,看到了Macros>>
在这里插入图片描述
打开,这下找到了比较全的Macros
在这里插入图片描述
找到$(XXXRootDir)这一行,Value中赫然写着 C:\root\xxx\ \m
这个\m到底是个什么鬼,怎么来的?我用echo查看了没有啊。

3.3 查看系统环境变量

绝望的我突然想到再去查一下系统环境变量,找到控制面板,搜索环境变量
在这里插入图片描述

在这里插入图片描述
赫然发现在用户变量那里有一个$(XXXRootDir)而且值就是 C:\root\xxx\ \m
再去系统变量那里,也有一个$(XXXRootDir),值是正确的C:\root\xxx\
到这里,应该真相大白了,原因就是那个用户变量里的错误值覆盖了系统变量里的那个正确值,处理方法也很简单粗暴,直接删了用户变量里那个。
再次打开csproj文件,一切正常。

4.思考

仍然有两个问题还没有解决。
一个是为什么会在用户变量中生成那个错误的值,关于这个问题,由于生成环境变量的那个脚本我不太熟,输入其他命令的时候会有\m的参数,不知道是不是用脚本的时候不小心输入了错误的参数。已不可考。
第二个问题是,为什么我用命令行输echo出来的值不对。后来也没有复现这个现象。推测是由于命令行是一开始就打开的,后来用脚本配置环境变量之后没有重新打开命令行,导致新的环境变量没有重新加载,因此输出的还是周期的正确的值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值