- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我编写了一个程序来计算我的红黑树中的平均路径长度。我发现了一件很奇怪的事情。代码如下所示:
while (dataSize<MaxSize) {
int i = 0;
double aveLengthArr[1000];
while (i < 1000) {
RedBlackTree rbt;
int* array= generateRandomInput(dataSize);
for (int n= 0; n < dataSize; n++) {
rbt->insert(array[n]);
}
aveLengthArr[i]=rbt->getAvePathLength();
i++;
}
double mean = calAverage(aveLengthArr);
double stdDeviation = calDeviation(aveLengthArr, mean);
dataSize++;
}
当使用特定行代码RedBlackTree rbt;
时,平均长度对于不同的输入array
仍然是相同的(我已经调试过了)。但是当代码更改为RedBlackTree* rbt=new RedBlackTree;
时,它得到了正确的结果并且长度发生了变化。
所以我真的很困惑,因为 rbt
是一个局部变量,对吧?每次程序跳入一个新的循环时,rbt
应该是一个全新的对象。即使不更新,长度也应该增加,但事实并非如此。使用指针后,就对了。
另一个奇怪的是,当我在Window7 中用代码RedBlackTree rbt;
运行程序时,结果是正确的。在使用 Ubuntu 时,它显示了上面的问题。任何想法都会受到赞赏。我真的很难弄明白。
RedBlackTree是红黑树,我把它写成一个自定义类,部分类如下:
class RedBlackTree {
private:
Node* root;
int redNodeNum;
int totalPathLength;
public:
RedBlackTree() {
redNodeNum = 0;
totalPathLength = 0;
}
}
最佳答案
您没有在构造函数中初始化 root
。
Every time the program jump into a new loop, the rbt should be a totally new object.
对象每次都被构造。但是每次循环中内存可能都在同一个地址(这不是保证)。并且由于您没有初始化 root
,您会看到一些未定义的行为,这又是 可能 保留循环中的最后一个值...但对编译条件、调试条件、优化...
https://en.wikipedia.org/wiki/Undefined_behavior
Another weird thing is that when I run the program with code RedBlackTree rbt; in Window7, the result is right. When using Ubuntu, it shows the problem above.
这就是未定义行为会发生的事情。
rbt->insert(array[n])
正如@SergeyTachenov 所指出的,这可能无法编译,因为您的 RedBlackTree 不是给定代码中的指针(因此必须是 rbt.insert(array[n])
。这可能是您在基于指针的版本和基于非指针的版本之间复制某些内容的产物。
发布完整且连贯的示例很重要,因此请阅读 MCVE: Minimal, Complete, Verifiable Examples .您问题中的代码最好按原样编译 in an online compiler并清楚地展示您的问题。
关于c++ - 为什么由指针和对象构建的局部变量显示不同的输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36248850/
有人可以解释一下为什么我得到: "use of unassigned local variable number_of_column" for: if (i f.LastWriteTime).Fir
我正在尝试为查询定义和初始化 MySQL 变量。 我有以下几点: declare @countTotal int; SET @countTotal = select COUNT(*) from nG
局部变量由小写字母或下划线(_)开头.局部变量不像全局和实变量一样在初始化前含nil值. ruby>$foo nil ruby>@foo nil ruby>foo ER
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
当我单击 Login 类上的注册按钮时,出现 nullpointerException,它给出了该错误。我尝试修改本地和全局变量,但似乎没有任何方法可以修复该错误,我可能在 onClickListen
我之前看过一些关于此的帖子,但我一直无法找到有关 actionListeners 的帖子。我正在尝试使用 JButton 数组创建井字棋。如果可能的话,如何在使用 for 循环临时变量的同时向它们添加
我试图找出一种将 getView() 方法中的位置变量传递给内部类的方法。但是,这不能是最终变量,因为 ListView 中的每个项目都会调用 getView() ,因此它会发生变化。有没有办法访问该
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
这对你们中的某些人来说似乎微不足道,但我对下面的这两个示例感到困惑。 int[] numbers = new int[] { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 }; int i
这个问题在这里已经有了答案: How do JavaScript closures work? (86 个答案) 关闭 7 年前。 所以我正在复习我的 vanilla Javascript,专门用于
我正在将mockito与spring(java 1.8)一起使用,并且我尝试在我的Answer对象中使用局部变量: public IProductDTO productForMock = null;
是否可以在java中为静态方法注入(inject)局部变量,比如 @Inject public void someMethod() { @MyInjectQualifier MyObjectC
我有一个函数,每 2 秒被重复调用一次,每次从屏幕顶部带来一个具有随机纹理的球。我希望能够在 touchesBegan 中使用这个球,但我不能,因为它是一个局部变量。我试过将它设为全局变量,但这给了我
这是(我假设)一个基本问题,但我似乎无法弄清楚。 给定以下代码: from src.Globals import * import pygame # Used to manage how fast t
这就是我在循环中引用全局变量的方法。 _.forEach(myTableName.detailsObjects, function (o, key) { if
我已经创建了一些代码: import numpy as np Length=(2.7)*10**-3 Nx=4 x = np.linspace(0, Length, Nx+1) # mes
如何获取局部变量? 我有这个代码 if (ctrl is Control) { Control c = (Control)ctrl; foreach (object innerCtrl
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Difference between class variables and class instance
我正在学习 Python 3,我有一个关于 Python 中面向对象编程的非常基本的问题。这是我的代码。 class pet: number_of_legs = 0 def count
我有以下代码块: class Student{ int age; //instance variable String name; //instance varia
我是一名优秀的程序员,十分优秀!