VC7.1的一个奇怪的bug

本文探讨了当两个命名空间以特定方式使用时,第一个命名空间的符号如何泄露到全局命名空间,导致编译错误C2872。文章还提到了这种现象在VC8.0上未出现,但在其他环境中影响了开发进度。

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

 

namespace n1
      struct    X{};
      int n1_i;
      
int fn(){return 0;}
}
namespace n2
{
        
using namespace n1;
        
enum {_};
}
struct X{};
n1::X x;
X gx;    
// ::X or n1::X ?, C2872: “X” : 不明确的符号
int i = n1_i;    // access n1::n1_i, OK
int i2 = fn();    // access n1::fn, OK

 

当两个命名空间有如上形式时,第一个命名空间的符号会“泄露”到全局命名空间。泄露发生的充要条件是:n2中using了n1,并且n2中至少有一个枚举项。

这样一来n1中的符号会污染全局命名空间,从而造成无故的符号解析多义,导致C2872编译错误。

如果把n2中的enum {_};改成enum{};则不会发生符号泄露。

 

在VC8.0上测试没有出现问题。目前还没找到一个较理想的解决办法。

 

这个bug造成的问题已经影响了我们的开发进度,如果我们使用的是正版VS2003不知道是否可以就此问题起诉微软。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值