为什么非下划线名称保留给 UDL 的实现,而不是相反
Why are non underscore names reserved to the implementation for UDL and not the other way around?
我知道这是一个古老的功能,但阅读用户定义的文字,例如
return_t operator "" _a(long); // Literal operator for user-defined INTEGRAL literal
有人提醒我
前导下划线是必需的。(仅允许标准库定义不带下划线的文本。(一)
这似乎打破了模式,因为到目前为止,该实现使用下划线名称并留给我们留下了好名称,例如保留给实现的名称
- 包含双下划线
- 以下划线开头,后跟大写字母
此外,在规则(2)存在的情况下,引用(A)有些危险。那么为什么不一致呢?
在将用户定义的文字的概念添加到语言之前,所有标准文字都使用不以下划线开头的序列,例如123L
表示long int
文字。因此,为了保持一致性,标准文本获取没有任何特殊前缀的命名空间,并且通过使用 _
将 UDL 与它们区分开来。
相关文章:
- 如果没有malloc,链表实现将失败
- 如何在c++中实现处理器调度模拟器
- 如何在c++中使用引用实现类似python的行为
- 实现无开销push_back的最佳方法是什么
- 使用简单类型列表实现的指数编译时间.为什么
- 如何在BST的这个简单递归实现中消除警告
- 实现一个在集合上迭代的模板函数
- 我应该实现右值推送功能吗?我应该使用std::move吗
- 如何正确实现和访问运算符的各种自定义枚举器
- C++Union/Struct位域的实现和可移植性
- 这个极客对极客的trie实现是否存在内存泄漏问题
- 在c++中实现LinkedList时,应出现未处理的错误
- 为左值和右值的包装器实现C++范围
- 使用模板进行堆栈实现; "name followed by :: must be a class or namespace"
- 使用GSoap实现ONVIF
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 用于AVX的ln(x)的实现,m256
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 在C++中,如何在类和函数(可能是模板化的)的头中编写完整的实现
- 为什么非下划线名称保留给 UDL 的实现,而不是相反