百科问答小站 logo
百科问答小站 font logo



c++ 中明明有vector了为什么还要有stack? 第1页

  

user avatar   miloyip 网友的相关建议: 
      

std::vector 是容器,而 std::stack容器适配器

std::stack只提供和堆栈相关的接口,其中主要是 push()emplace()pop()top()empty()。使用 std::stack时只需关心这些接口,而非内在用了哪个具体容器。改变容器类型也不需要修改调用方的代码。这个设计应该可说是乎合 SOLID 中的 I ──接口隔离原则(interface segregation principle)。

std::stack 可适配的标准容器有 std::vectorstd::liststd::deque,而 std::deque 是缺省的,因为它提供 的push_back(),而 std::vector::push_back()均摊(amortized)

为什么我想不出这种面试题⋯⋯




  

相关话题

  如何向完全不懂编程的小伙伴解释「程序写死」? 
  如何理解 Golang 中“不要通过共享内存来通信,而应该通过通信来共享内存”? 
  如何评价 C++ 11 auto 关键字? 
  Visual Studio 2019可以用来玩C语言吗? 
  为什么标准库的map要insert(pair(key,value))而不是insert(key,value)? 
  这条语句违背了C++哪个原则? 
  C++的核心究竟是什么?学到什么程度才算精通? 
  memcpy比循环赋值快吗?为什么? 
  Visual Studio 2019可以用来玩C语言吗? 
  udp文件传输的问题,采用nack,怎么处理最后几个包丢失的情况? 

前一个讨论
如何消除内心的浮躁?
下一个讨论
什么是图灵完备?





© 2024-12-26 - tinynew.org. All Rights Reserved.
© 2024-12-26 - tinynew.org. 保留所有权利