首页 >后端开发 >C++ >为什么两个不同的计算概念被称为'堆”?

为什么两个不同的计算概念被称为'堆”?

Barbara Streisand
Barbara Streisand原创
2024-11-08 14:25:02488浏览

Why Are Two Distinct Computing Concepts Called

为什么两个不同的计算概念都被称为“堆”?

在编程领域,经常使用“堆”这个术语指两个不同的概念:用于动态内存分配的运行时堆和称为堆的数据结构。虽然它们具有相同的名称,但自然会出现一个问题:这两个概念之间是否存在任何内在联系?

为了阐明这个问题,让我们深入研究该词采用的历史背景。正如计算机科学先驱 Donald Knuth 所指出的,“堆”在内存分配中的使用出现在 1975 年左右。然而,Knuth 指出,该术语在优先级队列方面已经有了明确的含义,代表传统意义上的优先级队列。高德纳认为,这个通用术语的原因是两个概念的共同特征。对于运行时堆,它充当内存库,随着新数据的分配而动态扩展。类似地,在堆数据结构的情况下,元素以树状排列存储,父级的优先级高于子级,从而可以有效检索最高优先级的元素。

总而言之,虽然“堆”这两个不同的概念在不同的上下文中使用,它们有一个共同的主题:提供一种有效的机制来存储和管理数据。对这两个概念采用相同的术语可能是因为它们在这方面的共性。

以上是为什么两个不同的计算概念被称为'堆”?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn