在c++中声明指针指向指针的效率
Efficiency of declaring a pointer to a pointer in C++
这听起来像是一个小问题,但是在我创建的程序中,我有一个递归函数,在这个函数中我声明了一个指向类'QuadTree'的指针的指针。
。:
void check_tree(QuadTree* p_qtree, Object* p_obj)
{
if (!p_qtree->is_leaf())
{
QuadTree** children = p_qtree->get_children(); // <-- WHAT I'M REFERRING TO
for (int i = 0; i < 4; i++)
check_tree(children[i], p_obj);
}
else
{
...
}
}
在递归函数中声明"四叉树**"是否会因为重复调用函数而降低程序的效率,或者其影响可以忽略不计?像下面这样在函数外声明它更好吗?
QuadTree** children; // <-- MOVE DECLARATION TO HERE
void check_tree(QuadTree* p_qtree, Object* p_obj)
{
if (!p_qtree->is_leaf())
{
children = p_qtree->get_children();
for (int i = 0; i < 4; i++)
check_tree(children[i], p_obj);
}
else
{
...
}
}
我最初的想法是在递归函数中声明指向指针的指针的影响可以忽略不计,因为它只为指针而不是整个类分配内存,但我不太确定。
性能方面,分配大小为n的堆栈和大小为m的堆栈之间没有区别(它们都编译为读取寄存器,添加常量值,并将值存储回相同的寄存器)。
内存方面,通过在函数内声明变量,每层堆栈将使用额外的8字节(64位机器)或4字节(32位机器)。国际海事组织,可以忽略不计。而且,编译器可以在安全的情况下将其优化掉。
正确性方面,在外部分配内存使函数不可重入。当您使用多个线程时,这可能是一个问题。
这种行为被称为二星编程,通常被认为是不好的。
你可以很容易地用引用代替(既"高性能"又可读):
void check_tree(QuadTree& p_qtree, Object& p_obj) {
if (!p_qtree.is_leaf()) {
QuadTree& children = p_qtree.get_children(); // should return a reference to QuadTree
for (int i = 0; i < 4; i++)
check_tree(children, p_obj);
}
// ...
}
就性能而言,每个指针都是额外的间接层。但是编译器优化的方式是无限的
在这种情况下,在外部声明它会导致一个bug:当第二次递归调用check_tree
时,如果在另一个非叶子变量中有一个非叶子变量,则children
变量将被覆盖。
check_tree
children = something
recursive check_tree when i=0
children = overwritten with something
recursive check_tree when i=1 -> has the incorrect "children".
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 为什么使用 "this" 指针调用派生成员函数?
- 函数向量_指针有不同的原型,我可以构建一个吗
- 使用指针从C++中的数组中获取最大值
- 助记符和指向成员语法的指针
- 嵌入方指针压缩已禁用
- 数组的指针从不分段故障
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 何时在引用或唯一指针上使用移动语义
- QMetaObject invokeMethod的基于函数指针的语法
- 如何从 std::atomic 中提取指针 T<T>?
- 如何在 C# 中映射双 C 结构指针?
- C++将浮点指针值舍入为小数位数
- 为什么++(*p)更改指针值
- 调整大小后指向元素值的指针unordered_map有效?
- 共享指针的复制和交换效率
- 64 位平台上的效率:指针与 32 位数组索引
- 间接指针对效率的影响有多大?
- 在c++中声明指针指向指针的效率