官术网_书友最值得收藏!

Summary

Both classical polymorphism and generic programming deal with the essential problem of parameterizing the behavior of an algorithm: for example, writing a search function that works with any arbitrary matching operation.

Classical polymorphism tackles that problem by specifying an abstract base class with a closed set of virtual member functions, and writing polymorphic functions that accept pointers or references to instances of concrete classes inheriting from that base class.

Generic programming tackles the same problem by specifying a concept with a closed set of requirements, and instantiating function templates with concrete classes modeling that concept.

Classical polymorphism has trouble with higher-level parameterizations (for example, manipulating function objects of any signature) and with relationships between types (for example, manipulating the elements of an arbitrary container). Therefore, the Standard Template Library uses a great deal of template-based generic programming, and hardly any classical polymorphism.

When you use generic programming, it will help if you keep in mind the conceptual requirements of your types, or even write them down explicitly; but as of C++17, the compiler cannot directly help you check those requirements.

主站蜘蛛池模板: 临汾市| 玉田县| 永昌县| 波密县| 格尔木市| 安国市| 武川县| 石嘴山市| 连山| 双柏县| 天峨县| 静安区| 乌鲁木齐市| 手游| 砚山县| 马山县| 依安县| 九龙城区| 永济市| 湘潭市| 宜兰市| 大庆市| 龙泉市| 来宾市| 钦州市| 湟源县| 辰溪县| 新疆| 嘉义县| 白城市| 古田县| 汉源县| 塘沽区| 黄浦区| 嘉荫县| 额济纳旗| 建宁县| 新余市| 浦江县| 于都县| 东台市|