此代码从对话框中获取一个字符串,并将其与列表中的数据进行比较,如果succesfull设置列表中元素的选择。 我遇到的问题是,如果它工作,如果我只搜索第一个元素,如果我尝试搜索任何其他的,它只是忽略如果条件,并一直走到列表的结尾。如果条件,没有代码正确执行代码
void CMFC1Dlg::OnBnClickedButton6()
{
CString variable;
cautare.GetWindowTextA(variable);
variable = variable.MakeLower();
if(variable!="")
{
list<Contact*>::iterator seek;
bool flag = TRUE;
int i = 0 ;
while(flag)
{
seek = agenda.first_element();
if(((CString)((*seek)->getLastName().c_str())).MakeLower() == variable ||
((CString)((*seek)->getFirstName().c_str())).MakeLower() == variable ||
((CString)((*seek)->getFirstAndLastName().c_str())).MakeLower() == variable ||
((CString)((*seek)->getLastAndFirstName().c_str())).MakeLower() == variable)
{
contactsVariable.SetCurSel(i);
this->OnLbnSelchangeList1();
flag=FALSE;
}
advance(seek,i);
i++;
if (i == agenda.list_size())
{
flag = FALSE;
}
}
}
else
MessageBox("No text on input ", "Error", MB_ICONERROR | MB_OK);
cautare.SetFocus();
cautare.SetWindowTextA("");
}
没有,我需要寻求每次都被设置为第一要素,所以当我前进时,我到达列表中的“我”元素 – Karudi 2011-05-19 16:33:30
如果他这样做,提前方法会导致非常奇怪的行为。 – Osiris76 2011-05-19 16:33:59
@Karudi:'advance(seek,i);我++;'应该在'if()'之前。 – 2011-05-19 16:42:33