将mysql数据库内容读到listcontrol问题
新建一个listcontrol控件,风格report,关联了变量,从mysql数据库读出数据插入到list时程序崩溃
m_list .insertitem()执行不过去导致崩溃,断点跟踪:insertitem()函数中ASSERT(::iswindow(m_hWnd)),其中m_hwnd的值为空:
Cwnd hWnd=0x0000000,问题应该出在这,但我不知道这个句柄为什么为空,该如何解决这个问题,谢谢了,在线等
------解决思路----------------------
引用:新建一个listcontrol控件,风格report,关联了变量,从mysql数据库读出数据插入到list时程序崩溃
m_list .insertitem()执行不过去导致崩溃,断点跟踪:insertitem()函数中ASSERT(::iswindow(m_hWnd)),其中m_hwnd的值为空:
Cwnd hWnd=0x0000000,问题应该出在这,但我不知道这个句柄为什么为空,该如何解决这个问题,谢谢了,在线等
一直在用CListCtrl控件显示数据库资源,没出现过你说的问题
根据你所提供的解释,个人感觉,应该是你把
m_list .insertitem();方法放到了错误的位置
void plugclass::GetDllUser(CString strUserJson, CListCtrl& mList)
{
USES_CONVERSION;
FastWriter fw;
Json::Reader reader;
Json::Value jValue,map;
CString strGetUser;
char * szBuff = CStringToChar(strUserJson);
CString userType[] = {L"管理员",L"加油员",L"",L"",L"",L"",L"",L"",L"",L"超级管理",};
mList.DeleteAllItems();
if (reader.parse(szBuff,jValue))
{
const Json::Value arrayObj = jValue["rows"];
int len = arrayObj.size();
for (int i = 0;i
{
map["userId"] = Value(W2A((CString)arrayObj[i]["userId"].asString().c_str()));
//strGetUser = dllUsers((CString)fw.write(map).c_str(),3);
mList.InsertItem(0,(CString)arrayObj[i]["userName"].asString().c_str());
mList.SetItemText(0,1,L"########");
mList.SetItemText(0,2,(CString)arrayObj[i]["realName"].asString().c_str());
mList.SetItemText(0,3,userType[_ttoi((CString)arrayObj[i]["userType"].asString().c_str())]);
mList.SetItemText(0,4,(CString)arrayObj[i]["userId"].asString().c_str());
}
}
mList.Invalidate();
delete szBuff;
szBuff = NULL;
}
以上是一段从json里读取数据到listctrl里的代码