启动/停止排序算法的C++矢量内存错误
C++ vector memory errors for a start/stop sorting algorithm
我有两个问题,第一,下面的代码由于内存或未初始化的位置错误而随机退出,我就是看不到它。第二,我不确定算法是否正确。(该算法被认为是为任何关心的人模拟汉伯里-布朗-特维斯光子实验)
矢量由线性增加的时间戳组成,其中停止信号延迟180秒,如果第i个启动信号小于第i个停止信号,则计时器启动,忽略所有启动信号,直到计时器遇到停止信号,反之亦然,如果计时器停止,则应忽略所有停止,直到登记启动。然后,代码应该对这些启动/停止之间的时间差进行桶式排序。
-如果有这种类型的名字,请在下面发布。
下面的代码采用这些填充的矢量,并尝试模拟这个过程。但在我重新修复算法之前,我无法弄清楚内存问题出了什么问题。
这是我的代码,它并不总是有效的,它适用于小于10000倍的开始/停止向量,但我需要它迭代到100000倍。
while( starts.size() > 5 && stops.size() > 5 ){
if( start.at(0) >= stop.at(0) ){
thisStart = starts.at(0);
}
j=0;
while( stops.at(j) <= starts.at(0) ){
j++;
}
stops.erase(stops.begin(), stops.begin() + j + 1 );
thisStop = stops.at(0);
j=0;
while( starts.at(j) <= thisStop){
j++;
}
starts.erase(starts.begin(), starts.begin() + j+1 );
bucketSort(thisStop - thisStart, bins, &counts);
}
while( stops.at(j) <= starts.at(0) ){
j++;
}
如果这个循环在stops
中找不到小于或等于starts[0]
的元素,那么它将越界。会抛出一个out_of_range
异常,这就是at()
应该做的。我不知道这是否是你的问题,因为你没有具体说明你得到了什么样的错误,但这肯定是需要查找的。
你可能想要这样的条件:
while (j < stops.size() && stops[j] <= starts[0]) { ... }
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 有没有一种方法可以使用placement new将堆叠对象分配给分配的内存