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

Templates

It's often thought that templates in C++ are very heavy, and carry a severe penalty for using them. This completely misses the point of templates, which is that templates are merely meant to be used as a shorthand method for automating the generation of nearly identical code from a single template – hence the name.

What this effectively means is that for any function or class template we define, the compiler will generate an inline implementation of the template each time the template is referenced.

This is a pattern we commonly see in the C++ standard template library (STL), which, as the name suggests, makes heavy use of templates. Take, for example, a data structure like a humble map:

std::map<std::string, int> myMap; 

What happens here is that the singular template for an std::map is taken by the compiler, along with the template parameters we provide within the sharp brackets, filling in the template and writing an inline implementation in its spot.

Effectively, we get the same implementation as if we had written the entire data structure implementation by hand just for those two types. Since the alternative would be to write every implementation by hand for every conceivable built-in type and additional user-defined type, the use of a generic template saves us a lot of time, without sacrificing performance.

主站蜘蛛池模板: 江阴市| 平阳县| 遵义县| 绥化市| 龙江县| 上思县| 天全县| 太仓市| 洛阳市| 新竹县| 利辛县| 贵州省| 武清区| 汶川县| 双流县| 兴仁县| 古蔺县| 漳浦县| 宁阳县| 蒙自县| 永仁县| 合肥市| 襄樊市| 平原县| 东丽区| 凤庆县| 长乐市| 依安县| 车险| 广昌县| 玉龙| 鄂托克前旗| 泰兴市| 精河县| 洱源县| 龙南县| 凤翔县| 茂名市| 常熟市| 富顺县| 广河县|