传统的标准C库头和重载的C++函数
Legacy standard C library headers and overloaded C++ functions
C++语言标准在D.5中说明
2每个C标头(每个标头的名称形式为
name.h
)的行为就好像由相应的cname
报头被放置在全局命名空间内范围未指定这些名称是首先声明的还是在名称空间std
的名称空间范围(3.3.6)内定义,并且是然后通过显式使用声明(7.3.3)。3[示例:标头
<cstdlib>
在命名空间CCD_ 5。它还可以在全局命名空间。报头<stdlib.h>
确实提供了相同的全局命名空间中的声明和定义,与C标准。它还可以在命名空间中提供这些名称std
--结束示例]
这似乎相当明确地声明("…每个名称…","…相同的声明…"),旧式<name.h>
标头必须提供与新型<cname>
标头相同的声明集,但在全局命名空间中。例如,各种C函数的特定于C++的重载版本没有例外。
这似乎意味着<math.h>
必须在全局命名空间中提供sin
函数的三个版本:sin(float)
、sin(double)
和sin(long double)
。反过来,这意味着下面的C++代码应该无法通过过载分辨率
#include <math.h>
int main() {
sin(1);
}
它在MSVC++编译器下确实失败了,但在GCC和Clang下编译成功。那么,GCC是否只是忽略了关于不推荐使用的旧式标头的标准要求?或者我不知怎么误解了标准中的措辞?
感谢@hvd的评论,我看到了曙光,结果证明MSVC是正确的,GCC也应该抱怨这种模糊性。
包括<cmath>
和<math.h>
之间的唯一区别是名称最初的作用域在哪里,前者在namespace std
中,后者在全局命名空间中(实现也可以自由地在其他命名空间中提供名称,但这不是强制性的),以及不赞成包括C头的.h
变体。
- 继承函数的重载解析
- 你能重载对象变量名本身返回的内容吗
- 从父命名空间重载类型
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 重载操作程序时出错>>用于类中的字符串 memebr
- 一个关于在C++中重载布尔运算符的问题
- 不同翻译单元中不可重载的非内联函数定义
- 为什么使用SFINAE而不是函数重载
- 为什么我不能在 C++ 中的特定函数重载中调用同一函数的任何其他重载?
- 将重载的成员函数传递给函数模板
- c++:可变模板和函数重载
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 重载==不适用于二进制树
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 重载运算符new[]的行为取决于析构函数
- 正在尝试重载二进制搜索树分配运算符
- 重载Singly Linked List中的赋值运算符
- 取消引用运算符不能重载