这篇文章主要讲解了“C++怎么避免互补性约束”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++怎么避免互补性约束”吧!
专注于为中小企业提供成都网站建设、做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业平桂免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上1000家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
T.25:避免互补约束
Clarity. Maintainability. Functions with complementary requirements expressed using negation are brittle.
清晰性。可维护性。包含互补的,使用否定方式表达的需求的函数是脆弱的。
Example (using TS concepts)(示例(使用TS概念))
Initially, people will try to define functions with complementary requirements:
最开始,人们试图用互补需求定义函数:
template
requires !C // bad
void f();
template
requires C
void f();
This is better:
下面的代码更好:
template // general template
void f();
template // specialization by concept
requires C
void f();
The compiler will choose the unconstrained template only when C
只有在C
template
void f() = delete;
The compiler will select the overload and emit an appropriate error.
编译器会选择重载重载并报出适当的错误。
Note(注意)
Complementary constraints are unfortunately common in enable_if code:
很不幸,互补的约束在enable_if代码中很常见:
template
enable_if, void> // bad
f();
template
enable_if, void>
f();
Complementary requirements on one requirements is sometimes (wrongly) considered manageable. However, for two or more requirements the number of definitions needs can go up exponentially (2,4,8,16,...):
一个需求上的互补需求有时(被错误地)认为是可控的。然而,对于两个或更多的需求,定义的数目需要可以按照指数方式增长。
C1 && C2
!C1 && C2
C1 && !C2
!C1 && !C2
Now the opportunities for errors multiply.
现在错误的可能性也倍增了。
Enforcement(实施建议)
Flag pairs of functions with C
标记使用C
感谢各位的阅读,以上就是“C++怎么避免互补性约束”的内容了,经过本文的学习后,相信大家对C++怎么避免互补性约束这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!