WPF多线程

第1种用 Task类. 推荐用这个办法
复制代码publicvoid工作_Task()

{

Dispatcher x
=Dispatcher.CurrentDispatcher;//取得当前工作线程

//另开线程工作

Task<int>计数=newTask<int>(()=>{return计数方法(); });

计数.ContinueWith(工作完毕后方法);
//工作完毕后执行的方法

计数.Start();//开始工作



}

publicvoid工作完毕后方法(Task<int>参数)

{

if(参数.IsCompleted)//正常工作完毕

{

var 结果
=参数.Result;//取得结果

//处理结果.

//本方法非界面线程.如果需要在界面线程操作,需要转移到界面线程

}

}



intc;

publicint计数方法()

{

returnc++;

}
复制代码
第2种方法用线程.
复制代码publicvoid工作_Thread()

{

Dispatcher x
=Dispatcher.CurrentDispatcher;//取得当前工作线程

//另开线程工作

System.Threading.ThreadStart start=delegate()

{

//工作函数

Func<string>fu=newFunc<string>(()=>{return""; });//工作函数

var 工作结果=fu();//开始工作



//异步更新界面

x.BeginInvoke(newAction(()=>

{

//在界面线程操作 可以使用 工作结果

}), DispatcherPriority.Normal);

};

newSystem.Threading.Thread(start).Start();//启动线程

}复制代码
第3种方法用 BackgroundWorker.

这种方法介绍的比较多了.就不说了.
复制代码BackgroundWorker 后台线程;

publicvoid线程初始化()

{

后台线程
=newBackgroundWorker();

后台线程.WorkerSupportsCancellation
=true;//可以取消

后台线程.DoWork+=newDoWorkEventHandler(后台线程_DoWork);

后台线程.RunWorkerCompleted
+=newRunWorkerCompletedEventHandler(后台线程_RunWorkerCompleted);

}

publicvoid启动后台线程()

{

后台线程.RunWorkerAsync();

}



void后台线程_RunWorkerCompleted(objectsender, RunWorkerCompletedEventArgs e)

{

//工作完毕的方法

}



void后台线程_DoWork(objectsender, DoWorkEventArgs e)

{

//工作方法

}复制代码原文链接: https://www.cnblogs.com/LYunF/archive/2012/11/06/2757003.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/68353

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月9日 下午1:17
下一篇 2023年2月9日 下午1:18

相关推荐