这个问题是关于C#线程内部操作datagridview 使数据重新加载实现向上跑动!!!

2025-03-23 00:42:38
推荐回答(3个)
回答(1):

由于你没给更多的数据,我只能给你以下代码,你自己试试吧。

(new Thread(new ThreadStart(() =>
{
    DataTable dt = new DataTable();
    dt.Columns.Add("A");
    dt.Rows.Add("A1");
    if (dataGridView1.InvokeRequired)
    {
        dataGridView1.BeginInvoke(new MethodInvoker(() =>
        {
            dataGridView1.DataSource = dt;
        }));
    }
    else
    {
        dataGridView1.DataSource = dt;
    }
}))).Start();

 

PS:简便写法需要framework>=3.5

回答(2):

CheckForIllegalCrossThreadCalls = false;
CheckForIllegalCrossThreadCalls在.net1.x中默认是false,也就是不检查,.net2.0和3.x默认是true
也就是说你也可以直接用.net 1.x
死穴:安全性 CheckForIllegalCrossThreadCalls容许子线呈随时更新ui,在同一个test函数体内,不能保证自身事务的一致性。给label1付了值 一回头,就已经被别人改了,这和超市的踩踏事件的后果一样严重。 当然你可以自己加锁,用信号量,这样还不如直接使用Invoke了,你只是又把别人做好的事情做了一遍。
如果你觉的你的应用不会考虑在写入ui的同时来读取ui,而倾向使用CheckForIllegalCrossThreadCalls来追求效率的话,也是不恰当的做法。 首先CheckForIllegalCrossThreadCalls并不能让效率发生本质的变化。 其次需求永远是变化的,现在不考虑不等于以后不会碰到 听从ms的引导。否则以后要在高版本的.net framework中移植代码的时候需要花费数倍的人工。

回答(3):

多线程更新窗体控件推荐使用委托,可以参考这篇文章 http://www.cnblogs.com/hnfxs/p/3192009.html
如果嫌前面的内容麻烦就直接看最后的那个方法就行了。