c++ - 数据管理错误 C++

标签 c++ arrays loops memory-management

我的代码遇到困难。问题是,即使我的程序一路运行,最后仍然崩溃。我的 IDE 没有给我任何反对意见,也没有任何迹象表明为什么我的程序最后会失败,所以我相信有什么东西超出了范围或有什么东西弄乱了我的堆栈。我查看了我的代码,没有发现任何超出范围的内容,因此我对此事完全感到困惑。

我正在使用我创建的头文件、包含头文件中的函数的文件和主方法文件。该错误是包含我的函数的文件导致的。

我类(class)的字段是 大小 - 整数

低 - 整数

高整数

窗口大小 - 整数

*filteredArray - 整数

数组[] - 整数

这是头文件:

#ifndef FILTER_HPP_
#define FILTER_HPP_
#include<iostream>


class Filter {
    int size;
    int high;
    int low;
    int windowSize;
    int *filteredArray;
    int array[];
    public:
        // Constructor
        Filter(int windowSize);
        // Methods
        void randArrayGen();
        int* randArrayGenRecurHelper(int arrayRecur[], int count);
        void randArrayGenRecur();
        void printArrays();
        int hanning(int ar[]);
        void hanningFilter();
        void graphicArrays();
        int getSize();
        int getHigh();
        int getLow();

};





#endif /* FILTER_HPP_ */

这是代码:

#include "Filter.hpp"
#include <iostream>
#include <time.h>
#include <stdlib.h>
#include <cmath>
#include <array>
#include <string>
#include <cstring>
using namespace std;

// Constructor
Filter::Filter(int num){
    size = ((rand() % 25) + 25);
    high = ((rand() % 6) + 5);
    low = ((rand() % 6) + 5) * -1;
    windowSize = num;
    randArrayGen();
    hanningFilter();

}


void Filter::randArrayGen(){
    for(int i = 0; i < size;i++){
        array[i] = (rand() % (high + low * -1)) + low;
    }
}




int Filter::hanning(int ar[]){
    int weightAvg;

    if(windowSize == 3){
        weightAvg = (ar[0] + ar[1] * 2 +ar[2]) / 4;
    }
    else if(windowSize == 5){
        weightAvg = (ar[0] + ar[1] * 2 + ar[2] * 3 + ar[3] * 2 + ar[4]) / 9;
    }
    else if(windowSize == 7){
        weightAvg = (ar[0] + ar[1] * 2 + ar[2] * 3 + ar[3] * 4 + ar[4] *3 + ar[5] * 2 + ar[6]) / 16;
    }
    else if(windowSize == 9){
            weightAvg = (ar[0] + ar[1] * 2 +ar[2] * 3 + ar[3] * 4 + ar[4] * 5 + ar[5] * 4 + ar[6] * 3 + ar[7] * 2 + ar[8]) / 25;
        }
    else{
        weightAvg = 0;
    }
    return weightAvg;
}



void Filter::hanningFilter(){
    filteredArray = new int[size];
    for(int i = 0; i < size; i++){
        if(i - (windowSize/2) < 0 or i + (windowSize/2) > size - 1){
            filteredArray[i] = 0;
        }
        else{
            filteredArray[i] = hanning(&array[i-(windowSize/2)]);
        }
    }
}



int Filter::getHigh(){
    return high;
}

int Filter::getLow(){
    return low;
}

int Filter::getSize(){
    return size;
}

最佳答案

您没有为数组分配内存:

int array[];

当你像这样索引它时:

for(int i = 0; i < size;i++){
    array[i] = (rand() % (high + low * -1)) + low;
}

您调用了未定义的行为,因为您超出了范围(例如,您请求第一个元素,但来自未知大小的数组)。

您可以声明具有固定大小的数组,例如:

int array[100];

但是,由于这是 C++,请考虑使用 std::vector 。一个直接的优势是,您不必为静态分配的数组硬编码大小,但您可以依靠 vector 在数据插入/插入时调整大小的能力。

关于c++ - 数据管理错误 C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46577363/

相关文章:

python - 如何在函数中逐一加载和处理具有多行的文本文件

C++在循环中创建线程并将它们存储在 vector 中

c++ - 不同模型的转换不起作用

javascript - 假设我有两个包含相关数据的数组。如何搜索第一个数组并返回数组 1 和数组 2 之间合并的相关数据?

c++ - 在类中的 lcd 对象上调用函数

PHP - 设置 file_get_contents 超时

ios - 'didSet' 数组中的某些元素 - Swift

Python 数组操作,pi*[n+1]^2 - pi*[n]^2

c++ - 如果我在锁定互斥锁之前解锁它可以吗?

c++ - 管道上的 read() 没有阻塞