VC++ CLR DataGridView 虚拟模式卡CPU问题

最近开发了一个数据解析程序,需要显示10W+的设备数据,采用了DataGridView 虚拟模式,效率非常高,但是使用中也遇到了一个奇葩的问题,微软MSN上面好像没有说到这个情况,比如我有10多列,界面默认只能显示前面计列,只要你把滑动条向右拖动了,也就是最前面不是第0列时,就会出现CPU占用非常大情况,同时会出现MessageBox无法弹出等情况。


正常情况如上图所示,CPU占用非常低。


只要把第一列挡住一点(向右拖动了滑条),此时CPU占用会瞬间变大,我的变为了34.2%,放到服务器上面会变成25%,根据CPU不同,占用会不一样,总的来说,CPU越强,占用越低,同时界面会花掉。


但是奇葩的是,你只要把第0列显示处理,一切都会恢复,cpu占用也正常了,界面也正常了。

通过我不断的测试,发现是只要拖动后,第0列没有显示处理,会一直触发dataGridView2_CellValueNeeded事件,获取最前面的那一列数据的值,但是我将此回调的数据一直返回为null后却没有这个问题,初步怀疑是需要将没有显示的列返回为null,接着进行测试。

最后找到问题原因是刷新了行号导致的尴尬

//DataGridView2 虚拟模式加载数据-用于主界面设备详细信息显示与操作
void CLASS_NAME::DataGridView2_CellValueNeeded(System::Object^  sender, System::Windows::Forms::DataGridViewCellValueEventArgs^  e)
{
	static int LastRowIndex = -1;
	char pStrBuff[512];

	if (this->isDisableRefreshDataGradView2 == true)	return;	//禁止刷新DataGradView2
	if (sender == nullptr || e == nullptr) return;
	try
	{
		if (LastRowIndex != e->RowIndex) //行更新了,刷新行号
		{
			char DecimalBuff[32];

			LastRowIndex = e->RowIndex;
			//显示行号
			sprintf_s(DecimalBuff, 32, "%d", e->RowIndex + 1);
			this->dataGridView2->Rows[e->RowIndex]->HeaderCell->Value = CharToString(DecimalBuff);
		}


		e->Value = this->GetDataGridViewCellData(pStrBuff, e->RowIndex, e->ColumnIndex);	//填充单元格
	}
	catch (Exception ^e)
	{
		SYS_LOG.Write(__FILE__ + __LINE__ + e->Message);
	}
}
去掉了中间的行号更新后终于解决了问题。



猜你喜欢

转载自blog.csdn.net/cp1300/article/details/79004204
CLR
今日推荐