提升labview程序性能-优化内存管理

提升labview程序性能-优化内存管理

ID:38438353

大小:1.44 MB

页数:27页

时间:2019-06-12

提升labview程序性能-优化内存管理_第1页
提升labview程序性能-优化内存管理_第2页
提升labview程序性能-优化内存管理_第3页
提升labview程序性能-优化内存管理_第4页
提升labview程序性能-优化内存管理_第5页
资源描述:

《提升labview程序性能-优化内存管理》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、提升LabVIEW程序性能-优化内存管理内容提要为什么要优化LabVIEW程序内存管理LabVIEW中监测VI内存占用和运行时间的工具优化LabVIEW程序内存管理基础篇高级篇为什么要优化LabVIEW程序内存管理LabVIEW的自动管理内存特性方便用户开发,满足一般应用需求LabVIEW应用程序趋向大型化,复杂化项目规模大,需求复杂数据处理量大,性能要求高好的编程风格帮助LabVIEW优化内存管理可以显著提高程序运行效率需要了解LabVIEW的内存分配机制监测VI内存占用和运行时间的工具帮助定位和分析程序中的瓶颈部分工具性能分析性能和内存显示VI内存分配情况的工具帮助分析程序中各个数

2、据变量的内存拷贝情况目标:消除黑点工具性能分析显示缓存区分配演示:监测VI内存占用和运行时间的工具优化LabVIEW程序内存管理-基础篇避免强制类型转换防止内存泄漏合理分配数组内存合理使用全局变量1数据类型转换强制点表明连接了两种不同的数据类型LabVIEW中类型强制转换需要数据备份涉及大数组的类型强制转换会占用大量内存推荐的类型转换方式更好的解决方式是在随机数创建时进行转换避免转换大块数据缓存(14.3KB)(22.7KB)2防止内存泄漏通常发生在文件操作或动态调用VI中注意关闭已打开的引用3合理分配数组内存过多进行内存重新分配占用很大开销慎用可能导致内存重新分配的相关函数创建数组连

3、接字符串演示:LabVIEW数组分配4合理使用全局变量增加程序可读性减少程序框图中的连线带来额外的内存开销全局变量需要数据备份避免对大数据变量使用全局变量例如大数组,图像,信号等等做到程序可读性和执行效率之间的平衡演示:全局变量的内存分配优化LabVIEW程序内存管理-高级篇利用移位寄存器shiftregister灵活使用LabVIEW自带的VI使用元素同址操作结构InPlaceElementStructure合理配置调用函数库节点CallLibraryNode1ShiftRegister-JeffKodosky的最佳创意之一!通过使用移位寄存器,规定输出端数据重用输入端数据内存,节省内存

4、开销举例:将输入数组的前半部分增大10倍演示:移位寄存器的使用查找并替换数组中的值2灵活使用LabVIEW自带的VI基本线性代数子程序VI(BasicLinearAlgebraSubroutines)合理归并基本线性代数操作减少不必要的内存复制开销使程序更加简洁数学线性代数BLASNEW!演示:使用BLASVI进行矩阵-向量乘法3元素同址操作结构更新数组或簇中的元素时,避免元素数据备份应用控制内存控制NEW!元素同址操作结构的优点方便实现多种情况的缓存重用,消除元素复制开销数组索引和替换簇的绑定和解除绑定波形的绑定和解除绑定变体的缓存重用任意元素的缓存重用举例:数组索引和替换将数组第

5、2个元素增大10倍方法一:方法二:元素数据备份举例:簇的绑定和解除绑定个人纳税信息的更新演示:嵌套的元素同址操作结构更新数组中单数号元素4合理配置调用函数库节点调用库函数节点中的Constant选项只有输入端,没有输出端,并确保在所调用的函数中没有修改所输入的数据此时选中Constant选项,LabVIEW不会对输入数据进行备份NEW!演示:配置调用库函数节点总结优化LabVIEW程序内存管理可以显著提高效率利用内存分配显示工具检查内存分配情况慎用可能导致内存分配的函数和全局变量灵活使用缓存重用技术移位寄存器shiftregister元素同址操作结构目标:尽量消除代表内存分配的黑点!!

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。