为什么STL的容器提供了top和pop两个函数,而没有合并成一个函数?

STL的stack、queue等容器,提供了top和pop两个独立的函数,而没有合并成一个函数,这是为什么呢?

首先,有一点很重要,即使容器为空,pop也是不会抛出异常的,这可能是由于STL希望自己的适用场景更加广泛,对于嵌入式以及向前兼容的代码,不要求一定要用try catch写代码。

有了这个大前提,就不难明白为什么STL如此设计了:

1. 首要是异常安全(exception-safe),如果将top和pop的功能合在一起,则返回值只能是一个对象,而不是引用,因为这个对象已经从容器里面移除了。那么,就至少会引起一次拷贝构造函数的调用(在引入移动构造函数之前),而拷贝构造函数可能会抛出异常。此外,如果是在函数返回的时候发生异常,top的元素已经被从容器移除了,而没有被正确返回,无法再把容器恢复到调用前的状态。

2. 其次是性能问题,合在一起,不能返回引用,不够高效。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章