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

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.

主站蜘蛛池模板: 乐山市| 都兰县| 大名县| 泉州市| 开原市| 叶城县| 抚远县| 牟定县| 崇义县| 区。| 新巴尔虎右旗| 瑞金市| 黄骅市| 罗平县| 建瓯市| 卓资县| 华蓥市| 宜州市| 康乐县| 抚顺市| 竹山县| 华容县| 梁平县| 祥云县| 秦安县| 定结县| 长沙县| 株洲市| 芜湖市| 固阳县| 北票市| 秦皇岛市| 米林县| 峨眉山市| 和硕县| 陆河县| 开原市| 开远市| 祁东县| 繁峙县| 吉林省|