本篇内容介绍了"丙怎么结合使用泛型和面向对象技术"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
T.5:结合使用泛型和面向对象技术应该增强它们的效果而不是成本
Reason(原因)
通用技术和面向对象技术是互补的。
泛型和面向对象技术是互补的。
Example(示例)
静态有助于动态使用静态多态实现动态多态接口。
静态协助动态:使用静态多态技术实现动态多态接口。
命令类{
//纯虚函数
};
//实现
模板/*.*/
类混凝土命令:公共命令{
//实现虚拟化
};
Example(示例)
动态帮助static:提供一个通用的、舒适的、静态绑定的接口,但是在内部动态调度,所以您提供了一个统一的对象布局。示例包括类型擦除,如共享_ptr的删除程序(但不要过度使用类型擦除)。
动态帮助静态:提供通用,舒适的静态边界的接口,但是内部进行动态分发,这样就可以提供一致的对象布局。示例代码引入了和std:shared_ptr的删除器一样的类型消除机制。
#包括内存
类对象{
公众号:
templatetypename T
对象
: concept _(STD :3360 make _ sharedConcreteCommandT(STD :正向t(obj))){ }
int get _ id()const { return concept _-get _ id();}
私人:
结构命令{
虚拟~命令(){}
虚拟int get_id()常量=0;
};
templatetypename T
结构体混凝土命令最终命令: {命令
除:对象_(STD :3360正向T(obj)){ }以外的具体命令(T obj)
int get _ id()const final { return object _ .get _ id();}
私人:
t对象_;
};
STD : shared _ ptrCommand concept _;
};
类别栏{
公众号:
int get_id()常量{返回1;}
};
struct Foo {
公众号:
int get_id()常量{ return 2;}
};
对象o(Bar { });
对象O2(Foo { });
Note(注意)
在类模板中,非虚函数只有在被使用时才会被实例化——但是虚函数每次都会被实例化。这可能会增加代码大小,并可能通过实例化从不需要的功能来过度约束泛型类型。避免这种情况,即使标准库方面犯了这个错误。
在类模板中,非虚函数只有在被使用时才会实例化-但是虚函数任何时候都会实例化。这会使代码膨胀,并且因为实例化根本不用的功能而过度约束通用类型。要避免这个问题,即使标准库有时也会犯这样的错误。
Enforcement(实施建议)
请参阅更具体规则的参考。
参见更加具体的规则。
"丙怎么结合使用泛型和面向对象技术"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/114471.html