Почему во второй раз я пытаюсь изменить свой JSON на строку, не работающую (окно вывода не отображается, даже если у меня есть breakpts или getchar)? - PullRequest
0 голосов
/ 28 мая 2018

Я пытаюсь преобразовать мой объект JSON в строку в тестовых примерах 1 и 4. Когда тестовый пример 4 удален, код работает правильно, как показано в выходных данных.Но когда я включаю тестовый пример 4, код не запускается.Код VS говорит об ошибке сегментации.Я попытался сделать j.get<decltype(s)>() для обоих, и код скомпилируется, но вывод не будет отображаться.Какие-нибудь решения?

    #include "records_manager_test.hpp"
    #include "records_manager.hpp"

    #include "nlohmann/json.hpp"

    using json = nlohmann::json;

    bool RecordsManagerTest::test1(){ //To test JSON
    json j = {
                {"1", {
                {"CategoryID",67},
                {"PatientID",90},
                {"Name","Foo"},
                {"Address","Bar"},
                {"DOB","100980"}
            }},
            {"2",{
                {"CategoryID", 6},
                {"PatientID", 9},
                {"Name", "Ryan"},
                {"Address", "161 University Ave"},
                {"DOB", "180998"}
            }}
        };
string s = j.dump(4);  //Stringfying JSON
RecordsManager test(s);
if(test.insertRecord(89,89,"Eric","161 University Avenue","010195"));
{
    test.printAsJSON();
    return true;
}
}

bool RecordsManagerTest::test2(){  // To test insert of record
RecordsManager test;
if(test.insertRecord(88,89,"Eric","161 University Avenue","040485")){
    if(test.insertRecord(88,90,"Ryan","161 University Avenue","160695")){
        return true;
    }
}
return false;
}

bool RecordsManagerTest::test3(){   //To test removal of record
RecordsManager test;
test.insertRecord(88,89,"Eric","dfdf","46465");
test.insertRecord(88,90,"Eric","dfdf","46465");
if(test.removeRecord(89,89))
    {
        test.printAsJSON();
        return true;
    }
return false;
 }

bool RecordsManagerTest::test4(){ //To test JSON
json j = {
            {"1", {
                {"CategoryID",67},
                {"PatientID",90},
                {"Name","Foo"},
                {"Address","Bar"},
                {"DOB","100980"}
            }},
            {"2",{
                {"CategoryID", 6},
                {"PatientID", 9},
                {"Name", "Ryan"},
                {"Address", "161 University Ave"},
                {"DOB", "180998"}
            }}
        };
//Stringfying JSON
string s1 = j.dump(4);
RecordsManager test(s1);
if(test.insertRecord(89,89,"Eric","161 University Avenue","010195"));
{
    test.printAsJSON();
    return true;
}
}
...