【问题标题】:Segmentation fault core dumped分段故障核心转储
【发布时间】:2014-01-03 22:01:25
【问题描述】:

我正在尝试从 c++ 创建一个 json 文件。使用的代码如下:

    Mat projected = eigenfacesExtraction(fileName);

    ofstream myfile;
    myfile.open ("detection.json");
    myfile << "{\n";
    myfile << "\t \"meta\":{\n";
    myfile << "\t \"duration\":\""<<duration<<"\",\n";  
    myfile << "\t \"fileName\":\""<<fileName<<"\"\n";
    myfile << "},\n";

    myfile << "\t \"num_of_people\":\""<< faces.size()<<"\",\n";
    myfile << "\t \"faces\":[\n";

    myfile << "\t \"projected\":[" << projected.size <<"] ,\n";

    for(int i=0; i<faces.size(); i++){

        if(!faces.empty()){ 
            if(i!= faces.size()-1){
            myfile << "\t \"coord\":\" \t[" << faces[i].x << ", "<<faces[i].y<< ", "<<      faces[i].width << ", "<<faces[i].height<<"],\n";
            myfile << "\t \"descr\":\" \t[" << projected.at<double>(0,1) << ", "<<projected.at<double>(0,2)<< ", "<<        projected.at<double>(0,3) << ", "<<projected.at<double>(0,4)<<"],\n";
            }
            else myfile << "\t \"coord\":\" \t[" << faces[i].x << ", "<<faces[i].y<< ", "<<     faces[i].width << ", "<<faces[i].height<<"]\n";
                 myfile << "\t \"descr\":\" \t[" << projected.at<double>(0,1) << ", "<<projected.at<double>(0,2)<< ", "<<       projected.at<double>(0,3)<< ", "<<projected.at<double>(0,4)<<"],\n";
        }
    }

    myfile << "]\n";
    myfile << "}";
    myfile.close();

    cout<< "Detection process exits...."<<endl;
    //imwrite( "/opencvAssets/results/"+fileName, image );
    imwrite("outputCapture.jpeg", image);
    //waitKey(0);
    //imshow("cropped image", croppedFaceImage);

我的程序工作正常,json 文件存储正确,cout 也会打印消息,但我收到以下消息“分段错误(核心转储)”。当我注释掉 iwrite 命令时,json 和 cout 都不起作用,我再次收到相同的消息。这是怎么回事?? eigenFacesExtraction 函数(可能会导致问题)如下:

 Mat Detection::eigenfacesExtraction(string fileName){

    Ptr<FaceRecognizer> model = createEigenFaceRecognizer();
    model->load("eigenfaces.yml"); // Load eigenfaces parameters
    Mat eigenvalues = model->getMat("eigenvalues"); // Eigen values of PCA
    Mat convMat = model->getMat("eigenvectors"); //Convariance matrix which contains eigenvectors
    Mat mean = model->getMat("mean"); // Mean value

    convMat.convertTo(convMat, CV_32F);
    mean.convertTo(mean, CV_32F);

    string path = fileName;

    Mat sample ,pca_ed_sample, resizedSample;
    sample = imread(path, CV_LOAD_IMAGE_GRAYSCALE);

    sample.convertTo(sample, CV_32F);
    resize(sample,resizedSample,Size(60,60),0,0,INTER_LINEAR);
    Mat nu =  resizedSample.reshape(1,3600).t();
    pca_ed_sample = (nu-mean)*(convMat);

    return pca_ed_sample;

}

【问题讨论】:

  • 条件是什么 if(i!= faces.size()-1) ?
  • 如果不是最后一个元素,则以逗号放在最后,在json文件中。
  • 它允许越界值。为什么不使用

标签: c++ json opencv core


【解决方案1】:

当我们尝试仅更改可读内存或尝试访问程序边界之外的内存时,会发生分段错误。将它放在调试器中并彻底跟踪它。有关更多信息,请查看此 stackoverflow 问题

What is a segmentation fault?

【讨论】:

    猜你喜欢
    • 2016-09-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多