Silverlight实用窍门系列:23.Silverlight多线程技术Thread的应用,后台线程更新UI控件,向多线程传递参数【附带源码实例】

简介:

 •在项目中时常会运行很多极其复杂的算法之后再更新UI控件,可是我们发现这会耗费大量的时间,几乎让UI进程假死。有什么办法可以让程序在后台完成这些复杂的算法,当算法完成的时候再去更新UI控件以避免UI进程假死的情况呢?对了,多线程技术!后台创建一个线程来进行复杂计算,就可以不耽误UI线程更新UI控件。可是如果直接在线程执行的函数里面去更新UI控件则会报“跨线程访问无效”的错误提示。下例中前台XAML文件里有两个UI控件label1和label2,在这里通过调用this.label1.Dispatcher.BeginInvoke方法执行labelInvoke委托的函数UpdateLabel(string content),在UpdateLabel函数里面就可以直接更新lable1控件需要显示的内容,同理可以更新其他的UI控件的显示。

        下面我们看一下如何在自创建的后台线程里面更新UI线程的label1控件:

复制代码

  
  
#region 启动一个无参数的只负责更新UI线程的自定义后台线程
public void NoParamThread()
{
Thread thread
= new Thread(ShowStr);
thread.IsBackground
= true ;
thread.Start();
}
/// <summary>
/// 显示Str的函数
/// </summary>
public void ShowStr()
{
string content = " 无参数传递的线程更新 " ;
// 运行labelInvoke委托的方法UpdateLabel,并且传递参数content
this .label1.Dispatcher.BeginInvoke( new labelInvoke(UpdateLabel),content);
}
/// <summary>
/// 更新Label的委托
/// </summary>
/// <param name="content"></param>
public delegate void labelInvoke( string content);
/// <summary>
/// 更新label1的方法
/// </summary>
/// <param name="content"></param>
public void UpdateLabel( string content)
{
// 更新UI线程上的 this.label1.Content值
this .label1.Content = content;
}
#endregion
复制代码

       •某一个函数运行需要2秒,输入5种不同的参数得到5个结果,那么一个线程来做这个事需要10秒。可做一个循环同时开5个线程运算这个函数并且带入参数,那么一共只需要2秒即可,这就是后台的多线程并行任务。

        下面请看如何来创建多个线程执行并行任务。首先循环创建5个线程,再为每个线程传入一个参数,但直接创建线程是无法传递参数的!这些参数如何传输进入线程执行的函数内部呢?在这里我们使用Thread thread = new Thread(new ParameterizedThreadStart(ShowString));的ParameterizedThreadStart对象来传递如参数。这样在线程的实例中运行thread.Start(object obj)重载函数即可传递一个参数。

复制代码

  
  
#region 启动传递一个参数的进程
public void HaveParamThread( string str)
{
// 循环创建5个线程
for ( int i = 0 ; i < 5 ; i ++ )
{
Thread thread
= new Thread( new ParameterizedThreadStart(ShowString));
thread.IsBackground
= true ;
thread.Start(str
+ i.ToString());
}
}
/// <summary>
/// 显示Str的函数
/// </summary>
public void ShowString( object content)
{
string con = content as string ;
// 做复杂运算
string strcon = con.Substring( 0 , con.Length - 2 );
// 运行labelInvoke委托的方法labelDelegete,并且传递参数con
this .label2.Dispatcher.BeginInvoke( new labelDelegete(UpdateLab), con);
}
/// <summary>
/// 更新Label2的委托
/// </summary>
/// <param name="content"></param>
public delegate void labelDelegete( string content);
/// <summary>
/// 更新label2的方法
/// </summary>
/// <param name="content"></param>
public void UpdateLab( string content)
{
// 更新UI线程上的 this.label1.Content值
this .label2.Content = this .label2.Content + " -- " + content;
}
#endregion
复制代码

       通过上面的实例,我们可以总结出在Silverlight中多线程技术通常用于以下两个方面。

       第一、加快UI控件响应,提高用户体验。通过UI线程和后台计算线程的分离,后台线程专注于计算, 计算完毕将结果推给前台UI线程显示出来。

       第二、后台多任务并行运算。同时开多个线程运行不同参数的一个复杂计算函数以节约计算时间。

       本实例采用VS2010+Silverlight 4.0编写,如需源码请点击 SLThread1.rar 下载。



    本文转自程兴亮博客园博客,原文链接:http://www.cnblogs.com/chengxingliang/archive/2011/03/10/1979927.html,如需转载请自行联系原作者

相关文章
|
16天前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
13 3
|
16天前
|
Java
在Java多线程编程中,实现Runnable接口通常优于继承Thread类
【10月更文挑战第20天】在Java多线程编程中,实现Runnable接口通常优于继承Thread类。原因包括:1) Java只支持单继承,实现接口不受此限制;2) Runnable接口便于代码复用和线程池管理;3) 分离任务与线程,提高灵活性。因此,实现Runnable接口是更佳选择。
27 2
|
16天前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
27 2
|
16天前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
26 1
|
1月前
|
存储 消息中间件 资源调度
C++ 多线程之初识多线程
这篇文章介绍了C++多线程的基本概念,包括进程和线程的定义、并发的实现方式,以及如何在C++中创建和管理线程,包括使用`std::thread`库、线程的join和detach方法,并通过示例代码展示了如何创建和使用多线程。
38 1
C++ 多线程之初识多线程
|
16天前
|
Java 开发者
在Java多线程编程中,选择合适的线程创建方法至关重要
【10月更文挑战第20天】在Java多线程编程中,选择合适的线程创建方法至关重要。本文通过案例分析,探讨了继承Thread类和实现Runnable接口两种方法的优缺点及适用场景,帮助开发者做出明智的选择。
13 2
|
16天前
|
安全 Java 开发者
Java多线程中的`wait()`、`notify()`和`notifyAll()`方法,探讨了它们在实现线程间通信和同步中的关键作用
本文深入解析了Java多线程中的`wait()`、`notify()`和`notifyAll()`方法,探讨了它们在实现线程间通信和同步中的关键作用。通过示例代码展示了如何正确使用这些方法,并分享了最佳实践,帮助开发者避免常见陷阱,提高多线程程序的稳定性和效率。
27 1
|
16天前
|
Java
在Java多线程编程中,`wait()` 和 `notify()/notifyAll()` 方法是线程间通信的核心机制。
在Java多线程编程中,`wait()` 和 `notify()/notifyAll()` 方法是线程间通信的核心机制。它们通过基于锁的方式,使线程在条件不满足时进入休眠状态,并在条件成立时被唤醒,从而有效解决数据一致性和同步问题。本文通过对比其他通信机制,展示了 `wait()` 和 `notify()` 的优势,并通过生产者-消费者模型的示例代码,详细说明了其使用方法和重要性。
21 1
|
2月前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
1月前
|
存储 前端开发 C++
C++ 多线程之带返回值的线程处理函数
这篇文章介绍了在C++中使用`async`函数、`packaged_task`和`promise`三种方法来创建带返回值的线程处理函数。
44 6