LabVIEW使用数据引用减少内存

简介: LabVIEW使用数据引用减少内存

概览 NI LabVIEW 省略了 开发 软件时 需要 手动 管理 内存。LabVIEW 编译器 始终 会 分析 您 的 代码, 以 确定 如何 优 化 性能 并 减少 所需 的 内存 量。但是, 想要 更多 控制 内存 分配 的 高级 用户 可以 在 LabVIEW 2009 中创建 数据 引用。

背景 分支 线路 通常 要求 LabVIEW 在 线路 上 创建 数据 的 副本。如果两个分支都修改该值,或者如果一个分支在使用原始值完成之前修改该值,则始终如此。使用 LabVIEW 工具 中的 “显示 缓冲 器 分配” 选项 来 突出显示 编 譯 器 将 分配 额外 内存 的 位置。 返回页首 基本示例 “新建数据值引用”节点将任何数据作为输入,并创建对数据的引用。请注意,如果数据被分叉并在其他地方使用,则仍可能发生复制。


53cc08c410fe33dc93ae4f24ce577c75.jpg



编辑


添加图片注释,不超过 140 字(可选)


图1.“新建数据值引用”节点创建对数据的引用,可用于以序列化方式传输和访问数据。 两个新节点可用于就地元素结构,以对数据进行操作,并在原始内存位置替换数据。同一个VI中可以存在多个就地元素结构,但一次只能对来自参考的数据进行操作,因为它们是阻塞函数以防止竞争条件。


1c28403d4a587bb01c32b0d60f7943e6.png



编辑切换为居中


添加图片注释,不超过 140 字(可选)


图2.此VI代码段说明了如何使用此功能的示例。要在LabVIEW 2009中尝试此示例,请将图像拖到框图中。 为了帮助您理解此图,请考虑下图中显示的各个组件:


  1. 为其创建引用的数据的值为 5。
  2. “新数据值”Reference.vi 为这位数据创建引用。
  3. 这是数据引用的常量外观的示例。
  4. 就地元素结构具有一对用于数据值引用读/写的节点,分别用于取消引用和重新引用数据。此结构阻止执行使用相同引用的其他结构,直到它完成并且数据被重新引用。
  5. 如果引用无效,则数据值引用读取节点的错误输出线为“True”。您还将从写入值引用节点收到此工作,因此您不必合并这些错误。
  6. “删除数据值”Reference.vi 结束引用的生存期并返回最后一个已知值。
  7. 这是前面板指示器的终端示例。


错误处理 如果 您 需要 同时 获取 多个 参考, LabVIEW 将 在 结构 边界 处 等待, 直到 获取 了 所有 参考 源。如果任何引用是错误的引用,则必须将所有错误合并在一起,然后才能知道是否要执行任何工作。 返回页首 对类使用引用 可以将数据引用用于任何数据类型,包括类。LabVIEW 类 具有 分层 关系, 对 类 的 引用 模拟 该 层次 结构。换句话说,期望父类引用的子VI可以传递子类引用。 LabVIEW 类 的 配置 选项 可 让 您 能够 限制 创建 和 销毁 对 类 成员 VI 的 引用。您可以保证,只要您在任何其他VI的图上遇到该类型,对该类的任何引用都是通过正确的初始化方法定义的。



a9b0876319c4a6b45315e8c1ab885ffd.png


编辑


添加图片注释,不超过 140 字(可选)


图3.您 可以 从 LabVIEW 类 的 属性 对话框 中 限制 对 类 的 引用 的 创建 和 删除。 如果类被标记为只有成员VI可以为该类创建引用,那么当您尝试在任何其他VI的图上创建对该类类型的引用时,New Data Reference函数就会中断 - 默认情况下启用此功能。不能限制对类的集群或类的数组的引用。 必须在运行时维护引用的类型,这意味着不能交换数据值。借助 新的 保留 运行 时间 Class.vi 基元, LabVIEW 可以 保证 运行 时间 类型 的 一致性, 您 可以 使用 该 来 交换 两个 值。如果需要允许您更改基础对象的类引用,请创建对该类的集群的引用。这使您能够以分层强制转换为代价交换值。


a9004c06d4053016c8b45196cfe25c7f.jpg



编辑


添加图片注释,不超过 140 字(可选)


图4.“保留运行时 Class.vi”使您能够交换不同引用的值。 第二个选项允许父类成为所有后代类型引用的独占工厂,默认情况下禁用。该限制的工作方式与对类本身的引用的限制相同。 如果您有子类的数据引用,则可以使用“到更多”Generic.vi 向上转换为父类引用。同样,以后可以使用“到更多”Specific.vi 将引用恢复为原始类型。当您将 ref-to-child-class 连线连接到 ref-to-parent-class 终端时,会出现向上投射强制点。

相关文章
|
8天前
|
存储 编译器 数据处理
C 语言结构体与位域:高效数据组织与内存优化
C语言中的结构体与位域是实现高效数据组织和内存优化的重要工具。结构体允许将不同类型的数据组合成一个整体,而位域则进一步允许对结构体成员的位进行精细控制,以节省内存空间。两者结合使用,可在嵌入式系统等资源受限环境中发挥巨大作用。
30 11
|
2月前
|
监控 算法 应用服务中间件
“四两拨千斤” —— 1.2MB 数据如何吃掉 10GB 内存
一个特殊请求引发服务器内存用量暴涨进而导致进程 OOM 的惨案。
|
2月前
|
存储 C语言
数据在内存中的存储方式
本文介绍了计算机中整数和浮点数的存储方式,包括整数的原码、反码、补码,以及浮点数的IEEE754标准存储格式。同时,探讨了大小端字节序的概念及其判断方法,通过实例代码展示了这些概念的实际应用。
63 1
|
2月前
|
存储
共用体在内存中如何存储数据
共用体(Union)在内存中为所有成员分配同一段内存空间,大小等于最大成员所需的空间。这意味着所有成员共享同一块内存,但同一时间只能存储其中一个成员的数据,无法同时保存多个成员的值。
|
2月前
|
监控 Java easyexcel
面试官:POI大量数据读取内存溢出?如何解决?
【10月更文挑战第14天】 在处理大量数据时,使用Apache POI库读取Excel文件可能会导致内存溢出的问题。这是因为POI在读取Excel文件时,会将整个文档加载到内存中,如果文件过大,就会消耗大量内存。以下是一些解决这一问题的策略:
104 1
|
2月前
|
缓存 安全 Java
使用 Java 内存模型解决多线程中的数据竞争问题
【10月更文挑战第11天】在 Java 多线程编程中,数据竞争是一个常见问题。通过使用 `synchronized` 关键字、`volatile` 关键字、原子类、显式锁、避免共享可变数据、合理设计数据结构、遵循线程安全原则和使用线程池等方法,可以有效解决数据竞争问题,确保程序的正确性和稳定性。
42 2
|
2月前
|
存储 编译器
数据在内存中的存储
数据在内存中的存储
42 4
|
4月前
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
387 0
|
2月前
|
存储 弹性计算 算法
前端大模型应用笔记(四):如何在资源受限例如1核和1G内存的端侧或ECS上运行一个合适的向量存储库及如何优化
本文探讨了在资源受限的嵌入式设备(如1核处理器和1GB内存)上实现高效向量存储和检索的方法,旨在支持端侧大模型应用。文章分析了Annoy、HNSWLib、NMSLib、FLANN、VP-Trees和Lshbox等向量存储库的特点与适用场景,推荐Annoy作为多数情况下的首选方案,并提出了数据预处理、索引优化、查询优化等策略以提升性能。通过这些方法,即使在资源受限的环境中也能实现高效的向量检索。
|
2月前
|
存储 Java
JVM知识体系学习四:排序规范(happens-before原则)、对象创建过程、对象的内存中存储布局、对象的大小、对象头内容、对象如何定位、对象如何分配
这篇文章详细地介绍了Java对象的创建过程、内存布局、对象头的MarkWord、对象的定位方式以及对象的分配策略,并深入探讨了happens-before原则以确保多线程环境下的正确同步。
57 0
JVM知识体系学习四:排序规范(happens-before原则)、对象创建过程、对象的内存中存储布局、对象的大小、对象头内容、对象如何定位、对象如何分配
下一篇
无影云桌面