第3章 LabVIEW与多线程_第1页
第3章 LabVIEW与多线程_第2页
第3章 LabVIEW与多线程_第3页
第3章 LabVIEW与多线程_第4页
第3章 LabVIEW与多线程_第5页
已阅读5页,还剩69页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、LabVIEW与多线程Intelligent Electronics InstituteHuazhong University of Science & TechnologyHttp:/2目录多线程技术LabVIEW多线程环境LabVIEW多线程程序设计LabVIEW线程通信与同步提示与建议习题Http:/33.1多线程技术n 基本概念 程序程序是指一个静态的指令序列; 进程进程为执行程序指令的线程而保留的一系列资源的集合; 线程线程是操作系统用来调度执行的最小单位。程序进程线程Http:/3.1多线程技术n 多线程多线程在运行一个多线程的程序时,为了运行所有的线程,操作系统为每个独立线程安排

2、一些CPU时间,每个线程在使用完时间片后交出控制权,系统再将CPU时间片分配给下一个线程。由于每个时间片足够短,这样就造成一种假象:好像这些线程在同时运行。 (a) 从用户角度看多线程 (b) 从系统角度看多线程 应用多线程技术的目的就是尽可能地利用CPU时间。4Http:/3.1多线程技术n 多处理器多处理器多处理器是指在一台计算机中有两个以上的处理器,每个处理器可以同时执行不同的线程。 在多处理器的作用下,多个线程可以同时执行,从而以更少的时间完成更多的任务。5Http:/3.1多线程技术n 线程调度线程调度 无论进程还是线程都是操作系统中进行CPU任务调度的程序单元; CPU调度一个进程

3、时必定发生一个进程上下文切换; CPU调度一个进程内的多个线程时则可以避免上下文切换的发生; 采用多线程可以减少因上下文切换导致的CPU时间开销。6Http:/3.1多线程技术n 在多进程操作系统中,当创建一个进程时系统同时就为进程创建了一个主线程,由这个主线程生成额外的子线程,然后这些线程又可以生成更多的子线程,所有的线程共同构成了一个进程的线程集。7Http:/3.1多线程技术n 线程优先级线程优先级 线程被调度的先后顺序是依据线程的优先级来完成的; 当一个线程被创建时,操作系统将分配给线程一个优先级; 在调度周期的开始,系统从线程的就绪队列中选择拥有最高优先级的线程来执行。8Http:/

4、3.1多线程技术n 影响线程调度的其它因素影响线程调度的其它因素 线程调度除了依据线程优先级以外,还受系统调度策略和算法等因素的影响; 调度算法的优劣直接影响到CPU运行的效率和性能,不佳的调度算法不仅可能降低系统的反应时间,而且可能导致某些线程或进程长时间得不到调度; 目前操作系统一般采用抢占式调度。9Http:/3.1多线程技术n 抢占式调度抢占式调度抢占式调度是指当一个线程或进程所分配的时间片过期或有更高优先级的线程或进程出现时,如果调度进程还需要进行上下文的切换,操作系统将暂停其在CPU上继续执行,调度另外的线程或进程到CPU上执行。 抢占式调度阻止了任何线程长期占用处理器的情况发生;

5、 最短任务优先调度策略偏向于预估完成时间最短的线程,有利于迅速减少系统中线程数量,提高处理器的吞吐量。10Http:/3.1多线程技术n 线程通信线程通信 如果线程间的通信发生在一个进程中,可以通过从堆栈片段传递值的方式来完成; 如果一个进程中的线程同另一个进程中的线程进行通信,则不能以线程通信的方式来处理,而必须以进程间通信来对待,采取如环境变量、命名管道、共享内存等技术手段来解决; 在多数情况下,线程通信的代价要小于进程通信的代价。11Http:/3.1多线程技术n 线程同步线程同步线程同步一般分为数据同步、设备同步和任务同步3种情况。 数据同步用于保证并发线程以一种安全的模式访问内存块;

6、 设备同步用于多个线程访问单一设备时对实时操作和优先权的严格控制,阻止线程破坏设备的状态; 任务同步用于加强线程间逻辑关系上的前置条件和后置条件。12Http:/3.2LabVIEW多线程环境n 支持多线程模式的程序设计语言支持多线程模式的程序设计语言 用函数直接创建多线程用函数直接创建多线程:在Visual C+语言中,提供了封装在Win32 API中的 CreateThread、ExitThread等函数方法的CWinThread类,为创建多线程应用程序提供了基本框架; 从执行系统和数据流控制数据流控制两个层次实现多线程程序设计:LabVIEW开发环境。13Http:/3.2LabVIEW

7、多线程环境n LabVIEWLabVIEW执行系统执行系统类似于Java虚拟机,是特有的中间执行平台。 LabVIEW程序框图编译生成的,并不是操作系统平台上的可执行程序代码,而是一种特有的程序组织代码,这种代码必须通过LabVIEW的执行系统来实现在操作系统上的运行; 在创建LabVIEW发布的可执行程序时,对于没有LabVIEW执行系统环境的计算机需要在发布组件选项中包含LabVIEW运行引擎(Run-Time Engine)。14Http:/3.2LabVIEW多线程环境n 执行子系统执行子系统(6(6个个) )用户界面(user interface)、标准(standard)、仪器I/

8、O(instrument I/O)、数据采集(data acquisition)、其他1(other 1)、其他2(other 2)。 u在“文件VI属性执行”面板中可以对执行子系统进行更改。15注意:“与调用方相同”(same as caller)不是一个子系统,它表示其执行子系统与调用该子VI的程序的执行子系统相同Http:/3.2LabVIEW多线程环境n 子系统分工子系统分工对执行系统进行细分的最初目的在于将不同用途的VI严格分配到不同的执行子系统中,各个执行子系统具体分工如下:用户界面子系统用户界面子系统:主要用于屏幕画图,以及键盘、鼠标输入等,这个子系统也用于特定类型的VI执行。标

9、准子系统标准子系统:如果需要为用户界面保持专用运行时间,应当为VI指定这个子系统。仪器仪器I/OI/O子系统子系统:该子系统主要用于完成与VXI系统、GPIB系统、串行仪器或网络之间的通信。数据采集子系统数据采集子系统:该子系统主要用于数据采集。其他子系统其他子系统1 1:当程序中的任务需要自己的线程时使用。其他子系统其他子系统2 2:当程序中的任务需要自己的线程时使用。16Http:/3.2LabVIEW多线程环境n 用户界面子系统用户界面子系统 用户界面子系统是LabVIEW系统运行时必须加载的,而其他几个执行子系统则是可选的; 用户界面子系统实际上是一个单线程系统,只有一个用户界面线程执

10、行各种任务; 在LabVIEW中所有与用户界面相关的操作都由用户界面子系统负责,其他执行子系统不负责管理用户界面。17Http:/3.2LabVIEW多线程环境n 线程数量设置线程数量设置 无法通过编写程序来实现对LabVIEW执行系统中线程变化的控制,但作为辅助工具,LabVIEW提供了一个线程配置程序threadconfig.vi,它位于LabVIEW安装目录vi.lib utilitiessysinfo.llb中; 一般情况下,不需要修改LabVIEW系统环境的默认线程数量设置。当LabVIEW系统运行在一个专用计算机专用计算机上,可以根据计算机的硬件配置情况适当增加线程的数量。而在一个

11、非专用计算机非专用计算机上增加LabVIEW系统中线程的数量,则可能影响其他程序的运行,甚至可能由于线程过多导致计算机整体性能的下降。18Http:/3.2LabVIEW多线程环境n 线程配置程序线程配置程序threadconfig.vithreadconfig.vi 线程配置程序界面 线程配置对话框19Http:/3.2LabVIEW多线程环境n VIVI优先级优先级LabVIEW程序优先级的设置方法可以分为程序控制和系统控制两种。程序控制方法程序控制方法是指用户通过在程序框图中使用等待函数来控制程序内部并行任务的执行顺序;系统控制方法系统控制方法是通过在VI属性中选择相应的VI执行优先级别

12、来控制VI的执行顺序。 20任务1,优先级高任务2,优先级低Http:/3.2LabVIEW多线程环境n 注意注意VIVI的优先级问题的优先级问题 考虑修改VI的优先级设置时要慎重小心,一般情况下,用户创建VI的默认为普通优先级,应尽量避免修改VI的优先级,只有那些特殊的VI才被指定为非普通的优先级; 在当一个VI确有必要使用非普通的优先级时,应当遵循这条原则:不要让高优先级的VI持续运行; VI优先级是隐含的,只能通过查询VI属性才能了解。21Http:/3.2LabVIEW多线程环境n 子程序优先级子程序优先级并不是一个真正的优先级,它并不标识VI的相对优先级别,仅用来标识一类特殊的Lab

13、VIEW程序,具有该优先级的VI不会被加入到执行子系统的运行队列中。 鲜明的特征:VI的用户界面不能更新,只能调用子程序优先级的子VI,不能调试等; 子程序优先级的VI可以调用其他子程序优先级的VI,不能调用其他优先级的VI。22Http:/3.2LabVIEW多线程环境n 子程序优先级子程序优先级当选择了子程序优先级后,以下几个选项就不能选择了:a) 打开时运行(Run when opened);b) 调用时挂起(Suspend when called);c) 运行时自动处理菜单(Auto handling of menus at launch);d) 允许调试(Allow debuggin

14、g);e) 调用时清除显示控件(Clear indicators when called)。23Http:/3.2LabVIEW多线程环境n 子程序优先级子程序优先级VIVI示例示例“字符串”选项板下的“删除空白”(Trim Whitespace.vi)24Http:/3.2LabVIEW多线程环境n 多线程程序的优势多线程程序的优势多线程技术在LabVIEW程序中充分发挥了重要的作用,具有以下几点优势: 更高效地使用CPU; 更好的系统可靠性; 更优化的多处理器性能。25Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化示例1:要求要求:监控重物的速度变化过程,绘制S-t(距

15、离时间)曲线、V-t(速度时间)曲线、V-S(速度距离)曲线并显示所有数据。初始程序分初始程序分3 3步执行步执行26第一帧:得到S-t数据Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化27第二帧:得到V-t数据Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化28第三帧:得到V-S数据Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化发挥多线程的优势,将程序优化为并行结构发挥多线程的优势,将程序优化为并行结构29并行结构下的优化程序Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化示例2:以一个数据采集程序为例来介绍最大化数

16、据流的编程。原程序由顺序结构实现原程序由顺序结构实现30第1帧有两个执行流程:一是产生波形;二是配置模拟输入和输出。Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化31第2帧的功能是发送波形数据。Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化32第3帧的功能是采集波形。Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化33第4帧的功能是停止输入和输出的任务。Http:/3.3LabVIEW多线程程序设计n 线程优化线程优化线程优化后的程序框图线程优化后的程序框图34这个程序是按照配置、产生波形、读取波形的顺序执行的。只有等到前一步骤中错误簇

17、的信息到达后,下一步骤才能执行。输入和输出配置VI函数采用并行结构,并使用合并错误函数来保证只有输入和输出都已经配置好之后才可以产生波形。Http:/3.3LabVIEW多线程程序设计n 超线程程序超线程程序无论是超线程计算机还是多处理器计算机,都可以采用超线程机制对应用程序进行性能优化。示例:计算所有大于2的质数。初步想法初步想法35单循环解质数程序框图。Http:/3.3LabVIEW多线程程序设计n 超线程程序超线程程序优化程序优化程序36双循环解质数程序框图。Http:/3.3LabVIEW多线程程序设计n 可重入技术可重入技术可以在“文件VI属性执行”框中设置VI为可重入,在可重入V

18、I中,每个调用都产生一个副本,有着独自的状态信息,这样在执行时,多个相同的子VI可以同时执行。 可重入执行在以下情况下是很有用的:a) VI需要等待一个特定的时间或者超时后才执行;b) VI中含有不能与其他实例共享的数据。37Http:/3.3LabVIEW多线程程序设计n 可重入技术可重入技术示例:设计一个仿真芯片74LS14 74LS14的功能图 施密特非门的传输特性38Http:/3.3LabVIEW多线程程序设计n 可重入技术可重入技术 芯片74LS14是由6个施密特非门构成,因此74LS14.vi同时需要调用6个shimit.vi子VI。39shimit.vi的程序框图。Http:/

19、3.3LabVIEW多线程程序设计n 可重入技术可重入技术4074LS14.vi的程序框图。Http:/3.4LabVIEW线程通信与同步n 局部变量局部变量 局部变量(Local Variable)是LabVIEW为改善图形化编程灵活性而专门设计的特殊节点,主要是解决数据和对象在同一VI程序中的复用问题。 局部变量实际上是程序框图中已经存在的某个对象的复制品。 需要某个对象既可读(读出当前值)又可写(写入更新值)时,就可以使用局部变量。41Http:/3.4LabVIEW线程通信与同步n 创建局部变量创建局部变量:两种方式 第一种方式是在按照“函数编程结构局部变量”路径创建,此时局部变量的图

20、标有一个问号,需要选择与之相关联的对象后方可使用; 第二种方式是选择目标对象的右键快捷菜单中的“创建局部变量”菜单项,放置到背面板的相应位置,这样就直接创建了该对象的局部变量。42Http:/3.4LabVIEW线程通信与同步n 局部变量有两种状态局部变量有两种状态:读状态和写状态 读状态相当于控制对象,外观和控制对象的端子相似,为宽边框; 写状态相当于显示对象,外观和显示对象相似,为细边框。n 局部变量最常用于两种情况局部变量最常用于两种情况:并行循环控制和对变量数值的更新 并行循环控制主要用于用一个变量同时控制几个并行While循环的情况; 变量数值的更新是指在程序运行时,同一个对象既可作

21、为输入给程序赋值,也可作为输出显示当前状态。43Http:/3.4LabVIEW线程通信与同步n 全局变量全局变量 如果要在几个VI间共享数据,局部变量无法解决,需要使用全局变量(Global Variable)来实现; 全局变量的创建方法为:按照“函数编程结构全局变量”路径创建,在程序框图中会生成一个“?”端子,这表示该变量尚未定义,该端子上有一个地球图标,双击未定义的全局变量端子,或用右键快捷菜单中的“打开前面板”命令可打开一个全局变量前面板,它用于定义全局变量的内容。44Http:/3.4LabVIEW线程通信与同步n 全局变量应用示例:全局变量应用示例:测速系统全局变量前面板看上去和普

22、通VI的前面板相似,但没有背面板。工具栏中也没有运行和调试的相关工具图标。45全局变量前面板。Http:/3.4LabVIEW线程通信与同步 测距仪器初始化程序测距仪器初始化程序46Http:/3.4LabVIEW线程通信与同步 测距仪器测试程序测距仪器测试程序47Http:/3.4LabVIEW线程通信与同步n 事件发生事件发生 事件发生(Occurrence)技术可以用来在VI或部分框图程序之间传递触发时间,利用事件发生技术可以避免轮询带来的系统资源浪费; 对于一般的应用来说,用户应从调用“产生事件发生”函数开始来创建事件发生参数值,该参数值必须要传递到所有其他事件操作中。然后,用户既可以

23、通过调用“等待事件发生”函数来发生,也可以通过设置事件功能来创建一个事件的发生。在LabVIEW环境中,可以有多重的“等待事件发生”函数节点存在,然后当与之联系的设置事件功能被调用时,所有的事件都会在同一时间触发。48Http:/3.4LabVIEW线程通信与同步n 事件发生示例事件发生示例 事件发生测试程序前面板事件发生测试程序前面板49Http:/3.4LabVIEW线程通信与同步 事件发生的测试程序框图事件发生的测试程序框图50Http:/3.4LabVIEW线程通信与同步 事件发生用户子事件发生用户子VIVI的程序框图的程序框图51Http:/3.4LabVIEW线程通信与同步n 通知

24、通知 通知(Notification)技术通常用于两个相互独立的框图程序之间或同一台计算机中两个不同VI之间的同步通信; 通知器(Notifier)是基于通知技术的通信工具,可以看做数据之间的邮箱,一部分框图程序向邮箱中发送数据,另一部分框图程序从这个邮箱中收取数据; 对于通知器,在没有通知消息发生时,程序框图处于等待状态,避免了无休止地循环检测,从而减少了计算机时间的浪费; 通知技术不能用于网络或VI Servers之间的通信。52Http:/3.4LabVIEW线程通信与同步n 通知流程通知流程 从调用“获取通知器引用”(Obtain Notifier)函数来开始创建通知参数值,使用该函数

25、时必须输入元素的数据类型; 通过“发送通知”(Send Notifier)发送信息; 接收方通过“等待通知”(Wait on Notifier)得到发送的信息。53Http:/3.4LabVIEW线程通信与同步n 通知器示例通知器示例 NotificationNotification测试程序前面板测试程序前面板54Http:/3.4LabVIEW线程通信与同步 通知测试程序框图通知测试程序框图55Http:/3.4LabVIEW线程通信与同步 通知用户子通知用户子VIVI的程序框图的程序框图56Http:/3.4LabVIEW线程通信与同步n 通知的优缺点通知的优缺点 通知和事件发生有些类似,

26、不需要使用轮询技术,减少了系统开销; 通知相比事件发生机制有一定的优势:事件发生不能传递数据,只能触发事件,而通知不仅可以传递数据,还可以通过“取消通知”函数删除信息; 通知也有一些不足:没有数据队列,有时会丢失一些事件,因为新的事件会覆盖旧的没有响应的事件。57Http:/3.4LabVIEW线程通信与同步n 队列队列 队列(Queue)结构是一种先进先出(FIFO)的结构; 用队列技术,可以将一个有序的消息(或数据)从一个程序中传递到另一个与之相独立的并行运行的程序中; 队列技术把数据发送到一个队列缓存中,如果没有程序将这些数据读出,这些数据将一直保存在队列缓存中,直到有一个程序将其读出并

27、删除; 如果有两个应用程序都在等待同一个队列中的同一条数据,只有那个动作快的程序会收到数据,动作慢的则不会收到预期的数据,因为这条数据已经被动作快的程序读出并删除了。58Http:/3.4LabVIEW线程通信与同步n 队列的应用示例队列的应用示例 QueueQueue测试程序前面板测试程序前面板59Http:/3.4LabVIEW线程通信与同步 队列测试程序框图队列测试程序框图60Http:/3.4LabVIEW线程通信与同步 队列用户子队列用户子VIVI的程序框图的程序框图61Http:/3.4LabVIEW线程通信与同步n 信号量信号量 信号量(Semaphore)技术可以用于限制同时访

28、问一个被保护的共享资源的任务数目; 通过一个公用的信号量,可以在某一时刻仅允许一个任务执行一个受保护的临界区代码; 信号量和其他同步机制是不同的,其他机制主要是唤醒一个等待任务,信号量则是告诉任务需要等待其他任务允许其执行时才执行,所以能够有效地保护公有资源。62Http:/3.4LabVIEW线程通信与同步n 信号量的应用示例信号量的应用示例 信号量测试程序前面板信号量测试程序前面板63Http:/3.4LabVIEW线程通信与同步 信号量测试程序框图信号量测试程序框图64Http:/3.4LabVIEW线程通信与同步 信号量用户子信号量用户子VIVI的程序框图的程序框图65Http:/3.4LabVIEW线程通信与同步n 集合点集合点 集

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论