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控件:

 


 
 
  1. #region 启动一个无参数的只负责更新UI线程的自定义后台线程 
  2. public void NoParamThread() 
  3. Thread thread = new Thread(ShowStr); 
  4. thread.IsBackground = true
  5. thread.Start(); 
  6. /// <summary> 
  7. /// 显示Str的函数 
  8. /// </summary> 
  9. public void ShowStr() 
  10. string content="无参数传递的线程更新"
  11. //运行labelInvoke委托的方法UpdateLabel,并且传递参数content 
  12. this.label1.Dispatcher.BeginInvoke(new labelInvoke(UpdateLabel),content); 
  13. /// <summary> 
  14. /// 更新Label的委托 
  15. /// </summary> 
  16. /// <param name="content"></param> 
  17. public delegate void labelInvoke(string content); 
  18. /// <summary> 
  19. /// 更新label1的方法 
  20. /// </summary> 
  21. /// <param name="content"></param> 
  22. public void UpdateLabel(string content) 
  23. //更新UI线程上的 this.label1.Content值 
  24. this.label1.Content = content; 
  25. #endregion 

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

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

 


 
 
  1. #region 启动传递一个参数的进程 
  2. public void HaveParamThread(string str) 
  3. //循环创建5个线程 
  4. for (int i = 0; i < 5; i++) 
  5. Thread thread = new Thread(new ParameterizedThreadStart(ShowString)); 
  6. thread.IsBackground = true
  7. thread.Start(str + i.ToString()); 
  8. /// <summary> 
  9. /// 显示Str的函数 
  10. /// </summary> 
  11. public void ShowString(object content) 
  12. string con = content as string; 
  13. //做复杂运算 
  14. string strcon = con.Substring(0, con.Length - 2); 
  15. //运行labelInvoke委托的方法labelDelegete,并且传递参数con 
  16. this.label2.Dispatcher.BeginInvoke(new labelDelegete(UpdateLab), con); 
  17. /// <summary> 
  18. /// 更新Label2的委托 
  19. /// </summary> 
  20. /// <param name="content"></param> 
  21. public delegate void labelDelegete(string content); 
  22. /// <summary> 
  23. /// 更新label2的方法 
  24. /// </summary> 
  25. /// <param name="content"></param> 
  26. public void UpdateLab(string content) 
  27. //更新UI线程上的 this.label1.Content值 
  28. this.label2.Content =this.label2.Content+"--"+ content; 
  29. #endregion 

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

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

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

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



本文转自程兴亮 51CTO博客,原文链接:http://blog.51cto.com/chengxingliang/821971

相关文章
|
6月前
|
安全 算法 Java
Java 多线程:线程安全与同步控制的深度解析
本文介绍了 Java 多线程开发的关键技术,涵盖线程的创建与启动、线程安全问题及其解决方案,包括 synchronized 关键字、原子类和线程间通信机制。通过示例代码讲解了多线程编程中的常见问题与优化方法,帮助开发者提升程序性能与稳定性。
319 0
|
6月前
|
数据采集 监控 调度
干货分享“用 多线程 爬取数据”:单线程 + 协程的效率反超 3 倍,这才是 Python 异步的正确打开方式
在 Python 爬虫中,多线程因 GIL 和切换开销效率低下,而协程通过用户态调度实现高并发,大幅提升爬取效率。本文详解协程原理、实战对比多线程性能,并提供最佳实践,助你掌握异步爬虫核心技术。
|
7月前
|
Java 数据挖掘 调度
Java 多线程创建零基础入门新手指南:从零开始全面学习多线程创建方法
本文从零基础角度出发,深入浅出地讲解Java多线程的创建方式。内容涵盖继承`Thread`类、实现`Runnable`接口、使用`Callable`和`Future`接口以及线程池的创建与管理等核心知识点。通过代码示例与应用场景分析,帮助读者理解每种方式的特点及适用场景,理论结合实践,轻松掌握Java多线程编程 essentials。
542 5
|
8月前
|
开发框架 前端开发 JavaScript
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发一
本文介绍了方舟开发框架(ArkUI)及其两种开发范式:基于ArkTS的声明式开发范式和类Web开发范式。ArkUI是用于构建HarmonyOS应用界面的UI框架,提供极简UI语法和基础设施。声明式开发范式使用ArkTS语言,以组件、动画和状态管理为核心,适合复杂团队协作;类Web开发范式采用HML、CSS、JavaScript三段式开发,适用于简单界面应用,贴近Web开发者习惯。文中还概述了两者的架构和基础能力,帮助开发者选择合适的范式进行高效开发。
289 15
|
8月前
|
编解码 前端开发 Java
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发三
本文介绍了基于声明式UI范式的图形绘制与动画效果实现方法,涵盖绘制图形、添加动画效果及常见组件说明三部分内容。在绘制图形部分,详细讲解了如何通过Circle组件为食物成分表添加圆形标签,以及使用Path组件结合SVG命令绘制自定义图形(如应用Logo)。动画效果部分则展示了如何利用animateTo实现闪屏动画,包括渐出、放大效果,并设置页面跳转;同时介绍了页面间共享元素转场动画的实现方式。最后,文章列举了声明式开发范式中的各类组件及其功能,帮助开发者快速上手构建复杂交互页面。
327 11
|
4月前
|
存储 开发者 容器
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
本文介绍了ArkTS语言中的Class类、泛型、接口、模块化、自定义组件及状态管理等核心概念,并结合代码示例讲解了对象属性、构造方法、继承、静态成员、访问修饰符等内容,同时涵盖了路由管理、生命周期和Stage模型等应用开发关键知识点。
434 1
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
|
7月前
|
JavaScript 前端开发 UED
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发四
本文介绍了Web组件开发与性能优化的相关内容。在Web组件开发部分,涵盖创建组件、设置样式与属性、添加事件和方法以及场景示例,如动态播放视频。性能提升方面,推荐使用数据懒加载、条件渲染替代显隐控制、Column/Row替代Flex、设置List组件宽高及调整cachedCount减少滑动白块等方法,以优化应用性能与用户体验。
291 56
|
7月前
|
编解码 UED 开发者
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发之常见布局
本文主要介绍了自适应布局与响应式布局的相关内容。自适应布局部分涵盖线性布局、层叠布局、弹性布局和网格布局,详细说明了各布局的特性及使用方法,例如线性布局中的排列、拉伸与缩放,弹性布局的方向、换行与对齐方式等。响应式布局则重点讲解了栅格系统和媒体查询,阐述如何通过栅格组件和媒体查询条件实现不同设备上的适配效果。这些技术帮助开发者灵活应对多尺寸屏幕的设计需求,提升用户体验。
414 55
|
11月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
748 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。