85

我不明白为什么我会收到错误:

“元素”的初始化被“案例”标签跳过。

有人可以向我解释吗?

void LinkedList::process_example(int choice) {
    switch(choice) {
    case 1:
        cout << endl << endl << "Current S = ";
        this->printSet();

        cout << "Enter an element :";
        char* element = "lol";

        //cin>>element;
        cin.clear();
        cin.ignore(200, '\n');

        this->Addelementfromback(element); //error is here
        cout << endl << endl << "Current S = ";

        this->printSet();
        break;

    case 2:
        this->check_element();
        break;

    case 3:
        cout << endl << endl;
        cout << "Current Set S = ";
        this->printSet();

        cout << endl << "S has ";
        int count = this ->check_cardinality();
        cout << count << " elements";
        break;
    }
}
4

2 回答 2

158

尝试 wrap casewith {},并将所有语句放入{}.

case 1:
{
   cout << endl << endl << "Current S = ";
   this->printSet();    
   // and other mess
}
break;

您应该将所有这些语句放在函数中,保持case语句清晰。例如,写这种风格:

case 1:
   initializeElement();
   break;
case 2:
   doSomethingElse();
   break;

链接

于 2013-02-03T04:24:51.933 回答
14

当一个变量在 one 中声明时case,下一个case在技术上仍然在同一个范围内,所以你可以在那里引用它,但是如果你在case没有先点击这个的情况下点击它,你最终会调用一个未初始化的变量。这个错误可以防止这种情况。

您需要做的就是在switch语句之​​前定义它,或者使用花括号{ }确保它在退出特定的case.

于 2017-09-29T09:52:32.093 回答