c ++奇怪的分段错误

时间:2012-03-26 16:33:19

标签: c++ class segmentation-fault

int Celda :: look(int dni)
{
    bool found = false; 
    int i = 0; int pos = -1;
    //tam_ sometimes have a strange value, but I only
    while(i < tam_ && !found){ 
        //touch tam_ in the constructor, is the size of Celda
        if(dni == bloques_[i]){    
           found = true;
            pos = i;
        }
        ++i;
    }
    return pos;
}

在main中,我调用另一个类的方法,该类调用其他使用我在这里复制的look方法的类。在某些情况下,它可以工作,但有时程序会停止给出分段错误。

当我使用调试器时,我创建了另一个用于存储tam_值的变量(tam_是int类型),当我到达该行或while循环(条件为tam_)时,有时会出现分段错误。 / p>

Celda的构造函数是:

Celda :: Celda(int tamanio)
{
bloques_ = new int[tamanio];
bloq_ocupados_ = 0;
tam_ = tamanio;
for(int i = 0 ; i < tam_ ; ++i){
    bloques_[i] = 0;
}

}

Tabla :: Tabla(int numcel, int tambloq)
{
    nceldas_ = numcel; 
    tam_bloque_ = tambloq;
    tabla_ = new Celda*[nceldas_];
    for(int i = 0 ; i < nceldas_ ; ++i){
        tabla_[i] = new Celda(tam_bloque_);
    }
    ocupadas_ = 0;
}

class Celda
{
    private:
        int* bloques_;
        int bloq_ocupados_;
        int tam_;

在公共区域

int Tabla :: busq_lineal(int dni) //si pos_dentro acaba valiendo -1, no se encontró
{
    bool encontrado = false; 
    int pos = hash(dni), comparaciones = 0, pos_dentro, pos_fuera;
    int tamaniotab = nceldas_ * tabla_[0]->gettam();
    while(!encontrado && comparaciones < tamaniotab){
        pos_dentro = tabla_[pos]->buscar(dni);
        if(pos_dentro != -1){ //si lo encuentro...
            encontrado = true;
            pos_fuera = pos;
            comparaciones += pos_dentro + 1;
        }else if(pos < nceldas_ - 1){ //mientras no nos salgamos de la tabla, avanzamos
            ++pos;
            comparaciones += tabla_[0]->gettam();
        }else {
            pos = 0; //si nos salimos, volvemos al principio
            comparaciones += tabla_[0]->gettam();
        }
    }
    return comparaciones;
}

2 个答案:

答案 0 :(得分:1)

错误最有可能出现在这一行:

int pos = hash(dni);

正如您所说,您的hash函数只返回dni % 199。只有在哈希表中至少有200个项目时,这才能正常工作。

答案 1 :(得分:-2)

难道不是“i ++”吗?

for(int i = 0 ; i < tam_ ; i++){
    bloques_[i] = 0;
}