- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道堆栈是如何在 C++ STL 中实现的,使用数组或链表,或者更复杂的东西。另外我怎么知道任何代码的标准片段是如何实现的?我已经尝试过通过谷歌搜索并编写自定义代码来获得想法,但这非常耗时,而且有时第 3 方网站不会透露任何有用的信息。
最佳答案
I wanted to know how the stack is implemented in C++ STL, using array or linked-list, or something even more sophisticated.
std::stack
是一个容器适配器。它使用您作为模板参数提供的容器类型。默认情况下,它使用std::deque
。
How to know, the exact data structures and algorithms used to implement a standard piece of code, like in C++ STL?
通过阅读源代码或文档(如果有)。如果两者都不可用,那么您可以询问向您出售实现方案的供应商。如果这也不是一个选择,您可以尝试逆向工程(假设这对您来说是合法的),但这个选项既不简单也不快速。
虽然该标准没有明确指定用于实现标准容器的数据结构,但它们的要求非常严格,以至于实现选择的自由度很小。在实践中:
std::list
使用双链表实现std::forward_list
.. 带有单链表std::vector
.. 具有指数增长的动态数组std::array
.. 毫不奇怪,有一个数组std::deque
.. 带有分段数组std::queue
和 std::stack
是按原样使用底层序列容器的容器适配器。std::priority_queue
是一个容器适配器,它在参数序列容器之上构建隐式二进制堆。std::basic_string
与 vector 类似,只是它以 null 结尾,并且对迭代器失效的要求不太严格,这允许实现对元素所在的小容器使用优化。存储在容器内存中,无需动态分配。关于c++ - 如何知道用于实现标准代码(例如 C++ STL)的确切数据结构和算法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59566372/
通过多次搜索和pytorch文档本身,我可以发现在嵌入层内部有一个查找表,用于存储嵌入向量。我无法理解的是: 在这一层的培训期间究竟发生了什么? 权重是多少,以及这些权重的梯度是如何计算的? 我的直觉
当应用程序有大量数据(400M)要写入非阻塞套接字时,write() 返回EWOULDBLOCK 或EAGAIN 当发送缓冲区变满时。 当套接字被(e)轮询时,我有时会看到发送缓冲区中有 7M 空间(
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我经常阅读一些编程语言对模块的支持(“一流”)(OCaml,Scala,TypeScript [?]),并且最近偶然发现了这样的答案,即在Scala的显着特征中引用模块作为一流公民。 我以为我很清楚模
我已经提交了一个自定义的开放图表故事,但它被拒绝并显示以下消息: 打开图表捐赠(行动类型)提交内容、操作、对象和使用说明必须以英文提交。您可以在应用程序面板的“本地化”选项卡中翻译操作和对象。 如果我
给定一个任意的 boolean 值列表,确定其中一个恰好为真的最优雅的方法是什么? 最明显的 hack 是类型转换:将 false 转换为 0,将 true 转换为 1,然后对它们求和,并返回 sum
这个问题在这里已经有了答案: When to use extern "C" in simple words? [duplicate] (7 个答案) 关闭 9 年前。 如果您想将此问题标记为重复问题
我是一名优秀的程序员,十分优秀!