c – 为什么编译器会在重载时停止名称查找?

c – 为什么编译器会在重载时停止名称查找?,第1张

概述我刚读过这篇文章: Fun with C++ namespaces 作者在遇到第一个时会显示编译器停止查找重载,这里使用命名空间. namespace A{ void f(int x); // like our std::sqrt(double)}namespace B{ struct S {}; // user-defined type with associated na 我刚读过这篇文章: Fun with C++ namespaces
作者在遇到第一个时会显示编译器停止查找重载,这里使用命名空间.

namespace A{   voID f(int x); // like our std::sqrt(double)}namespace B{   struct S {}; // user-defined type with associated namespace B   voID f(S);   voID f(int,int);   voID test1()   {      using namespace A; // using DIRECTIVE      f(1);              // ERROR  namespace A is not consIDered because                         //        B contains two overloads for 'f'      f(1,2);            // OK     B::f(int,int)      f(B::S());         // OK     B::f(S)   }      voID test2()   {      using A::f; // using DECLaraTION      f(1);       // OK     A::f(int)      f(1,2);     // ERROR  A::f  hIDes  B::f(int,int)      f(B::S());  // OK     B::f(S) due to ADL!   }}namespace C{   voID test3()   {      using namespace A; // using DIRECTIVE      f(1);              // OK     A::f(int)      f(B::S());         // OK     B::f(S) due to ADL!   }      voID test4()   {      using A::f; // using DECLaraTION      f(1);       // OK     A::f(int)      f(B::S());  // OK     B::f(S) due to ADL!   }}

为什么编译器应该停止?

编辑#1:问题确实存在:为什么标准这样说?

感谢所有的答案!

解决方法

the compiler stops looking for overloads when encountering the first one

不,它不会停止“遇到第一个”,否则你找不到B :: f(int,int)和B :: f(S).

它找到给定范围内的所有重载(不仅是第一个),但是在更远的范围内不会进一步查看.

这就像C中的所有名称查找一样,如果你有一个名为var的全局变量,在某些函数中你也有一个名为var的局部变量,使用函数中的名称将引用局部变量.这样更有用,你更有可能想要使用附近声明的变量,因为它在相关的代码中.

如果有人递给你一封信,并告诉你把弗雷德放在几米远的地方,戴着一枚徽章上写着“我是弗雷德”,你会不理睬他,走到外面继续寻找世界上的每一个人叫弗雷德?

总结

以上是内存溢出为你收集整理的c – 为什么编译器会在重载时停止名称查找?全部内容,希望文章能够帮你解决c – 为什么编译器会在重载时停止名称查找?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1216085.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存