本篇内容介绍了“C++中怎么使接口清晰明确”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
成都创新互联公司是专业的栖霞网站建设公司,栖霞接单;提供成都网站制作、网站设计、外贸网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行栖霞网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
I.1: Make interfaces explicit(使接口清晰明确)
Reason(原因)
Correctness. Assumptions not stated in an interface are easily overlooked and hard to test.
正确性。在接口中没有说明的假设很容易被忽视且难于测试。
Example, bad(反面示例)
通过全局(命名空间范围)变量(调用模式)控制函数行为的方式是隐晦且不易理解的,例如:
int round(double d){ return (round_up) ? ceil(d) : d; // don't: "invisible" dependency}
调用者不容易理解两次调用round(7.2)可能返回不同的结果。
Exception(例外)
有时我们通过环境变量控制一套操作的细节。例如,正常输出还是详细输出,也可能是调试还是优化。使用非局部控制的做法可能会难于理解,只可以应用在其他固定语义的实现细节的情况。
Example, bad(反面示例)
Reporting through non-local variables (e.g., errno
) is easily ignored.
For example:
通过非局部变量报告(例如错误编码)很容易被忽略。例如:
// don't: no test of printf's return valuefprintf(connection, "logging: %d %d %d\n", x, y, s);
如果连接被关闭而导致没有日志输出怎么办?
Alternative: Throw an exception. An exception cannot be ignored.
可选项:抛出异常。异常不会被忽略。
另一种说法:避免会用非局部或隐含状态通过接口传递信息。注意非const成员通过对象状态函数向另外一个成员函数传递信息的情况。
另一种说法:接口应该是一个或一组函数。接口可以是模板函数,函数组可以是类和类模板。
Enforcement(实施建议)
(Simple) A function should not make control-flow decisions based on the values of variables declared at namespace scope.
(简单)函数不应该根据命名空间范围中的变量决定控制流。
(Simple) A function should not write to variables declared at namespace scope.
(简单)函数不应该改写定义于命名空间范围的变量。
“C++中怎么使接口清晰明确”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
文章名称:C++中怎么使接口清晰明确
当前URL:http://scpingwu.com/article/peggps.html