子线程为什么不能访问主线程控件
5个回答
展开全部
1.新开的线程是无法直接访问UI控件的,如果需要访问,可以通过控件的Invoke方法,或者用 System.Threading.SynchronizationContext.Current.Post方法
2.一定不要在控件的内部事件处理方法里面使用Sleep等线程暂停方法!
像我这样写就不会阻塞了:
private void button1_Click(object sender, EventArgs e)
{
System.Threading.Thread thread = new System.Threading.Thread(() =>
{
while (true)
{
this.Invoke(new Action(() =>
{
label1.Text = (count++).ToString();
}));
System.Threading.Thread.Sleep(100);
}
});
thread.IsBackground = true;
thread.Start();
}
你把setmess这个线程方法Invoke到了UI的主线程上了,而这个线程里面有暂停方法,所以呢主线程也会暂停卡住。
而我的方法只是把“label1.Text = (count++).ToString();”Invoke到主线程,而那个新的线程并没有Invoke到主线程,所以在那个线程里面使用暂停就没事了!
假如有一个操作比较费时,或者需要等待之类的,就像我这样开始一个新的线程,所以的等待操作,费时的操作都在在这个线程里面做,当这些线程需要访问UI控件的时候,就用this.Invoke()这个方法!
2.一定不要在控件的内部事件处理方法里面使用Sleep等线程暂停方法!
像我这样写就不会阻塞了:
private void button1_Click(object sender, EventArgs e)
{
System.Threading.Thread thread = new System.Threading.Thread(() =>
{
while (true)
{
this.Invoke(new Action(() =>
{
label1.Text = (count++).ToString();
}));
System.Threading.Thread.Sleep(100);
}
});
thread.IsBackground = true;
thread.Start();
}
你把setmess这个线程方法Invoke到了UI的主线程上了,而这个线程里面有暂停方法,所以呢主线程也会暂停卡住。
而我的方法只是把“label1.Text = (count++).ToString();”Invoke到主线程,而那个新的线程并没有Invoke到主线程,所以在那个线程里面使用暂停就没事了!
假如有一个操作比较费时,或者需要等待之类的,就像我这样开始一个新的线程,所以的等待操作,费时的操作都在在这个线程里面做,当这些线程需要访问UI控件的时候,就用this.Invoke()这个方法!
展开全部
防止多个线程争夺同一资源时引发异常。解决方法有多种:
其一,非调试模式下运行程序,可避免此异常。
其二,在窗体的狗仔函数里写:Form.CheckForIllegalCrossThreadCalls = false;
其三,使用同步或者异步委托,让主线程执行子线程的代码(this.Invoke(委托)或者this.BeginInvoke(委托))
其一,非调试模式下运行程序,可避免此异常。
其二,在窗体的狗仔函数里写:Form.CheckForIllegalCrossThreadCalls = false;
其三,使用同步或者异步委托,让主线程执行子线程的代码(this.Invoke(委托)或者this.BeginInvoke(委托))
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
想从子线程访问UI线程,需要用委托。
在子线程触发委托,然后委托函数里面操作UI
在子线程触发委托,然后委托函数里面操作UI
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以的
load里面写
CheckForIllegalCrossThreadCalls = false;
load里面写
CheckForIllegalCrossThreadCalls = false;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
嘿嘿,原因很简间,避免被人恶意篡改,遭受攻击
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询