C# 调用函数后窗体假死失去响应
我想用线程处理函数,但是函数有返回值和参数。我用的异步调用也会出现假死现象publicdelegateintFuncHandle(intdata1,intdata2);i...
我想用线程处理函数,但是函数有返回值和参数。我用的异步调用也会出现假死现象
public delegate int FuncHandle(int data1, int data2);
int Foo(int data1, int data2)
{int i = 0;for (int x = 0; x < 50000; x++ ){for (int y = 0; y < 50000; y++) { i+=y; }}return i;}
private void Button_Click(object sender, RoutedEventArgs e)
{
FuncHandle fh = new FuncHandle(this.Foo);
IAsyncResult ar = fh.BeginInvoke(1, 3, null, fh);
int re = fh.EndInvoke(ar);
MessageBox.Show(re.ToString());
} 展开
public delegate int FuncHandle(int data1, int data2);
int Foo(int data1, int data2)
{int i = 0;for (int x = 0; x < 50000; x++ ){for (int y = 0; y < 50000; y++) { i+=y; }}return i;}
private void Button_Click(object sender, RoutedEventArgs e)
{
FuncHandle fh = new FuncHandle(this.Foo);
IAsyncResult ar = fh.BeginInvoke(1, 3, null, fh);
int re = fh.EndInvoke(ar);
MessageBox.Show(re.ToString());
} 展开
3个回答
展开全部
IAsyncResult ar = fh.BeginInvoke(1, 3, null, fh);
int re = fh.EndInvoke(ar);
这个还是相当于同步在执行啊。
直接新起一个线程多好啊?
Thread thread = new Thread(new ThreadStart(Foo));]
thread.IsBackground = true;
thread.Start();
然后在Foo的最后加上
this.BeginInvoke(new MethodInvoker(delegate()
{
MessageBox.Show(结果);
}));
int re = fh.EndInvoke(ar);
这个还是相当于同步在执行啊。
直接新起一个线程多好啊?
Thread thread = new Thread(new ThreadStart(Foo));]
thread.IsBackground = true;
thread.Start();
然后在Foo的最后加上
this.BeginInvoke(new MethodInvoker(delegate()
{
MessageBox.Show(结果);
}));
追问
需要接受一个返回值和给两个参数
追答
那可以利用 ParameterizedThreadStart 这个委托, 可以接受参数。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
异步回调假死?
您在异步过程中请使用:
Yourcontrol.BeginInvoke(即可)
记住千万不要用THIS.BEGININVOKE.
否则UI卡死
您在异步过程中请使用:
Yourcontrol.BeginInvoke(即可)
记住千万不要用THIS.BEGININVOKE.
否则UI卡死
追问
我这样也会失去响应
追答
如果使用BEGININVOKE失去响应的话.
我就知道您是怎么写的了.
您是在BEGININVOKE的函数内编写访问数据库的对吧..
只要是BEGININVOKE其实就已经同步UI了..
把BEGININVOKE函数内的内容删除的只剩下给窗体赋值即可..其他任何访问数据库,WESERVICE等等的代码全部不要
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
怎么写的呢?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询