control list 显示mysql,将mysql数据库内容读到listcontrol有关问题

将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里的代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值