实施互换功能持续复杂性
Implementation of swap function for deque with constant complexity
据说std :: Deque交换功能需要恒定时间,而不是线性。http://www.cplusplus.com/reference/deque/deque/swap-free/。该功能如何实现?
所有可重新分配的标准库容器(即,除了std::array
之外的所有标准库容器)必须将其内容存储在动态分配的内存中。那是因为它们可以任意生长,并且无法将任意存储在容器对象本身占据的固定空间中。换句话说,必须有可能container.size() > sizeof(container)
。
这意味着容器对象仅将A 指针存储在其内容上,而不是内容本身。因此,交换两个容器意味着简单地交换这些指针。以极为简化的形式:
template <class T>
class Container
{
T *_begin, *_end;
friend void swap(Container &a, Container &b)
{
std::swap(a._begin, b._begin);
std::swap(a._end, b._end);
}
};
当然,实际上,这对分配器等的存在很复杂,但是原理是相同的。
通常通过使用pimpl idiom隐藏了Deque的实现(每个Deque都构成实现的指针)。然后将指针换成。它也可能(也可能是)至少将其指向其缓冲区的指针,然后将其换成(与大小相关的相关成员)。
此帖子(副本和交换成语)与如何实现交换有关。
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 带内存和隔离功能的SQLite
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 具有未知值时的时间复杂性
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 关联容器的下界复杂性:成员函数与非成员函数
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 实施互换功能持续复杂性
- 两个功能并没有花时间我期望的,因为它们的复杂性很大,任何人都可以解释原因
- 该功能检测循环链接列表的时间复杂性是什么?