点击进入winfrom窗体时因为窗体需要加载数据比较耗时会出现窗体假死,这个怎麼用多线程解决?
2个回答
展开全部
private void Form1_Load(object sender, EventArgs e)
{
//可以设置一个lable,背景为一个动态图片,例如:loading....
Thread td = new Thread(new ThreadStart(LoadData));
td.IsBackground = true;
td.Start();
}
void LoadData()
{
//模拟加载数据的时间
Thread.Sleep(1000*5);
this.BeginInvoke(new MethodInvoker(delegate() {
//数据加载完成后,控制lable隐藏代码
//..................
}));
}
更多追问追答
追问
stringstrSql=”这里抓10万条数据”;
dataGridView1.DataSource = dbAccess.ExecuteDataSet(strSql,CommandType.Text,null).Tables[0];//这里通过调用封装好的方法返回一个datatable数据源给dataGridView1
重点:这里因为涉及到窗体的dataGridView1,所以抓数据界面会卡,所以这个线程该如何写
追答
上面的代码不能解决你的问题嘛?你把Thread.Sleep(1000*5);换成你取数据加载的过程不就可以了嘛。
展开全部
用多线程,或线程池来加载数据就好了
ThreadPool.QueueUserWorkItem(
new WaitCallback(obj =>
{
加载数据的代码。。。。。
加载完成后把界面上的进度条什么的隐藏起来,再显示原有界面
})
);
个人感觉用WPF来写会好一点,因为WPF是以数据来驱动的,而Winfrom是事件驱动
ThreadPool.QueueUserWorkItem(
new WaitCallback(obj =>
{
加载数据的代码。。。。。
加载完成后把界面上的进度条什么的隐藏起来,再显示原有界面
})
);
个人感觉用WPF来写会好一点,因为WPF是以数据来驱动的,而Winfrom是事件驱动
追问
stringstrSql=”这里抓10万条数据”;
dataGridView1.DataSource = dbAccess.ExecuteDataSet(strSql,CommandType.Text,null).Tables[0];//这里通过调用封装好的方法返回一个datatable数据源给dataGridView1
重点:这里因为涉及到窗体的dataGridView1,所以抓数据界面会卡,所以这个线程该如何写
追答
你可以先定义一个bool属性
private bool loadOver;
public bool LoadOver
{
get { return loadOver; }
set {
loadOver = value;
if(loadOver)//当loadOver为真时
{
这里加载你的窗口界面代码
}
}
}
public void Methed()
{
loadOver=false;
ThreadPool.QueueUserWorkItem(
new WaitCallback(obj =>
{
stringstrSql=”这里抓10万条数据”;
dataGridView1.DataSource = dbAccess.ExecuteDataSet(strSql,CommandType.Text,null).Tables[0];
loadOver=true;//给loadOver赋值时可以在属性代码中再加窗口加载的代码
})
);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询