3.3.6 VO-O语法- 流程算子
流程算子是VO语言最重要的一类语法算子。它们是VO语言特有的语法概念。这些算子属于容器算子,用于组织管理各类流程。这样的设计有利于流程的复用。可以将流程视为一个大级别的函数模块,在更大的业务逻辑中复用,从而降低业务开发的复杂度,提升流程的开发效率。
流程算子根据其运行方式及应用场景分为以下几种:
并行流程算子(ProcessOperator)
并行流程算子表示其容器内的算子在运行时是并行的,即每个算子都会被分配一个独立的线程,数据流在算子间流转。由于数据流是由多个数据集组成的,故而整个数据流实际是被并行处理的。这样可以大幅提升数据被处理的速度。
如下图的流程:
图中的所有算子运行时都会占据一个独立的线程,不仅图中的两个分支可以并行运行。当数据流拥有多个数据集时,标准的并行流水线的计算效果会在整个流程中实现。每个算子都在处理当前流经算子的数据流。由于算子间存在计算速度的差异。因此,算子间缺省拥有缓存队列,用来平衡算子间的计算速度差异。
串行流程算子(ChainOperator)
串行流程算子表示其容器内的算子在运行时是串行的,即所有算子会共享同一条线程。串行流程算子会根据流程逻辑,依次执行每一个算子直到流程运行完成。
这样的调度方式显然是没有性能优势的,但是可以极大的节省计算资源。有些业务场景会比较复杂,当进行流程编写时,可能需要几百个算子。如果使用并行流程算子调用,那么每次都要分配几百个线程。对于数据量不大,仅是业务复杂的场景来说,很多线程绝大多数情况都是闲置的,它们无效的占用了设备的算力。因此,为这些算子分配一个共享的线程来完成数据计算是一种更优的方案。
流程编写者可以根据实际的业务情况在流程编写时选用不同的流程算子,优化流程的调度运行。
流程引用算子(ProcessReference)
当需要在一个流程中嵌套使用另外一个流程的功能时,会用到流程引用算子。可以通过拖拽流程到流程定义空间面板的方式复用一个流程。被拖拽到空间面板的流程会被提示是使用“引用”模式还是“容器内运行”模式被嵌入流程。”引用“模式下,流程以”流程引用算子“的形式嵌入当前流程;”容器内运行“模式下,流程以”流程自驱算子“的形式嵌入当前流程。
流程引用算子在外观上看到的端口与其对应的流程一致。即其外观的端口是随被引用流程的端口状况变化的。比如被引用的流程(以下称子流程)有两个输入端口,两个输出端口,那么可以看到流程引用算子也是两个输入端口和两个输出端口。流程引用算子通过数据端口与主流程的数据流进行数据的交换。运行时,流程引用算子会装载子流程,并按照端口的连接情况,将数据传输给子流程。子流程经过计算,将数据输出到主流程进行后续的计算。
主流程
子流程
被引用的子流程一般都会有输入或输出端口。并通过输入或输出端口与主流程完成数据的交互。也有一种特殊的应用情况,子流程不需要提供任何输入、输出端口。此时,主流程通过控制流驱动子流程的运行,实现流程按照控制关系运行。即前置算子执行完,子流程开始执行,子流程执行结束后,后续算子开始运行。这样的运行逻辑可以用于如前置算子执行结束后,后续算子如果要执行,必须进行一个复杂的数据环境准备的场景。子流程可以用于实现数据环境的准备工作,且不需要与主流程有数据交换。
流程自驱算子(ReferenceExecution)
除了上节中提到的没有输入、输出端口的特殊子流程外。有时候我们编写的流程并不希望通过输入端口接收数据,而只是希望通过变量来驱动流程的执行。一种典型的编程思维模式,就是面向过程的编程模式。把编写好的流程看作是一个函数,通过变量为流程传递运行所需的参数。当引用这样的流程作为子流程时,就需要选择“流程自驱”算子了。
流程自驱算子的意思是,它会遍历输入的数据集,使用数据集中的每一条数据依次替换子流程中的变量,并驱动子流程运行。这种模式下,子流程会被独立装载运行多次。彼此之间不共享任何数据。与流程引用的不同之处在于,流程引用算子内的子流程只会被装载一次,子流程内的算子会自行批量处理输入子流程的数据集。
从流程引用算子和流程自驱算子的运行方式上我们可以看出,流程引用算子的运行效率更高;流程自驱算子的流程编写自由度更高,也更符合一般程序编程经验的思维方式。
相关文章:
3.3.6 VO-O语法- 流程算子
流程算子是VO语言最重要的一类语法算子。它们是VO语言特有的语法概念。这些算子属于容器算子,用于组织管理各类流程。这样的设计有利于流程的复用。可以将流程视为一个大级别的函数模块,在更大的业务逻辑中复用,从而降低业务开发的复杂度&…...
c++引入nacos,详细步骤
以下是将Nacos引入C项目的详细步骤,包括安装、配置和代码实现: 1. 安装Nacos服务器 下载Nacos服务器安装包,可以从Nacos官网获取最新版本。 解压安装包并启动Nacos服务器: cd nacos/bin sh startup.sh -m standalone 这将启动…...
OpenAI 最新发布的 GPT-4.1 系列在 API 中正式上线
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
亚远景-自动驾驶时代,ASPICE评估标准将如何演进?
自动驾驶时代,ASPICE评估标准将从以下几个方面演进: 1. 技术领域的扩展 增加硬件工程和机器学习过程组 :ASPICE 4.0版本新增了硬件工程和机器学习过程组,以应对自动驾驶系统中硬件与软件深度融合的需求。自动驾驶功能的实现不仅依…...
Redis 数据类型全解析:从基础到实战应用
精心整理了最新的面试资料和简历模板,有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 Redis 作为高性能的键值对存储系统,其丰富的数据类型是实现复杂业务逻辑的核心优势。本文将深入解析 Redis 六大核心数据类型及扩展类型ÿ…...
基于JSP+MySQL实现用户注册登录及短信发送功能
用户注册信息存入数据库 内容介绍 此项目是前台用户的登录和注册,,这部分包括两个子部分:其中一个为新用户注册,在这里我们可以通过注册浏览更多信息;另一个是用户登录,用户登录系统是一.般 Web 网站都有的子系统,其作用是限制该网站某些资…...
Spark-SQL核心编程2
路径问题 相对路径与绝对路径:建议使用绝对路径,避免复制粘贴导致的错误,必要时将斜杠改为双反斜杠。 数据处理与展示 SQL 风格语法:创建临时视图并使用 SQL 风格语法查询数据。 DSL 风格语法:使用 DSL 风格语法查询…...
Flink SQL SavePoint最佳实践
以下是 Flink SQL Savepoint 最佳实践,涵盖配置、触发、恢复及注意事项,高效管理作业状态: 一、Savepoint 的配置与触发 1. 基础配置 存储路径:在 flink-conf.yaml 中全局设置 Savepoint 存储目录,避免每次手动指定路…...
【无标题】Spark-SQL编程(2)
以下是今天学习的知识点以及代码测试: Spark-SQL核心编程(四) 实验内容: 利用IDEA开发Spark-SQL。 实验步骤: 利用IDEA开发Spark-SQL 创建子模块Spark-SQL,并添加依赖 <dependency> <grou…...
django项目之添加资产信息功能
资产信息功能添加 目录 1.创建表格 2.页面展示 3.新增和修改 4.删除 这篇文章的内容, 就是在前面做的基础上, 新增一个资产管理功能, 其实就和之前的部门信息还有员工信息差不多的, 但是这篇文章里面, 会有些细节的地方, 和之前的不太一样。那下面我们就开始讲述这篇文章…...
macos下 ~/.zshrc~ 和 ~/.zshrc
macos下 ~/.zshrc~ 和 ~/.zshrc ~/.zshrc通常是备份文件或临时文件,可能由编辑器(如vim)创建,通常可以安全删除,不会影响系统运行。 在Mac下,这种带~后缀的备份文件通常是由以下情况产生: 常…...
Kotlin集合操作陷阱与突围:如何优雅地边遍历边修改MutableList
在Kotlin开发中,MutableList是我们常用的集合类型之一。但当我们需要在遍历列表的同时修改它(添加或删除元素)时,很多开发者会遇到ConcurrentModificationException异常。本文将详细介绍如何安全高效地实现这一需求。 一、问题场…...
交换机与路由器的默契配合:它们的联系与区别
交换机与路由器的默契配合:它们的联系与区别 一. 交换机与路由器的基本功能1.1 交换机的功能1.2 路由器的功能 二. 交换机和路由器的区别三. 交换机和路由器的联系3.1 数据转发的协作3.2 网络分段与分隔3.3 协同工作提供互联网接入 四. 交换机和路由器的联合应用场景…...
cocos 3D自由世界游戏 - 开发
cocos 3D自由世界游戏 - 开发 序概述第一步 创建环境,XForge 框架基础3D创建思路场景地形树木等环境人物角色角色实现实现代码篇空间管理篇动画逻辑篇按钮实现篇虚拟摇杆多功能按钮移动和目标篇AI实现角色属性以及身份牌篇装备篇结尾序 在同时浅入了unity 和 cocos以来,得到…...
SOME/IP中”客户端消费“及”服务端提供”的解析
先上结论 AREthAddConsumedEventGroup-->客户端的函数-->谁调用 Consumed函数,谁就是消费者 AREthAddProvidedEventGroup-->服务端的函数-->谁调用 Provided函数,谁就是服务端 Server 端:AREthAddProvidedEventGroup → 声明 &…...
视频分析设备平台EasyCVR安防视频管理系统,打造电石生产智能视频监控新体系
一、背景介绍 电石生产中的出炉工序是整个生产流程中最为繁重且危险的环节。在开堵炉眼的过程中,电石极易发生飞溅现象,尤其在进行吹氧操作时,人员灼伤的风险极高。鉴于此,该工序正逐步由传统的人工操作模式向智能化方向转变。然…...
ffmpeg实现视频流抽帧
ffmpeg 实现视频流抽帧 抽取实时视频帧 如果你的实时视频是通过 RTSP、UDP 或其他协议获取的,可以直接调用 FFmpeg 命令来抽取帧。 ffmpeg 命令 示例 1 ffmpeg -i rtsp://your_rtsp_stream_url -vf fps1 -update 1 output.jpg说明: -i rtsp://your…...
VTK知识学习(51)- 交互与Widget(三)
1、概述 从前面的 内容可知,交互器样式(如 vtknteractorStylelmage)主要是根据不同的键盘、鼠标等消息来控制相机(vtkCamera)、Actor 等相关参数,从而达到交互的目的。而在渲染场景中,这些交互器样式是没有表达实体的。也就是说,在…...
蓝桥杯嵌入式开发板结构分析及功能学习笔记
目录 板子结构一览时钟源分析74LS573锁存器按键输入滴答定时器 SysTick串口收发LCD屏幕ADC采样AT24C02(EEPROM)可编程电阻TIM定时器输入捕获DAC 板子结构一览 主控为 **STM32G431RBT6**** 外部晶振频率为 **24MHz IAP下载为** GD32F350C8T6** 时钟源分析 自己配置的STM32Cu…...
C++进阶——C++11_智能指针
目录 1、问题引入 2、RAII和智能指针 3、C标准库的智能指针 3.1 auto_ptr (不好) 3.2 unique_ptr 3.3 shared_ptr (重点) 3.4 weak_ptr (重点) 4、shared_ptr的循环引用问题(重点) 5、shared_ptr的线程安全问题 6、C11智能指针和boost的关系 7、内存泄漏 7.1 什么是…...
音频格式转换
1. 下载ffmpeg https://www.gyan.dev/ffmpeg/builds/packages/ffmpeg-7.1.1-full_build.7z 2. 配置ffmpeg环境变量 3.安装pydub pip install pydub 4.编写转化工具代码 from pydub import AudioSegment def convertM4aToWav(m4a,wav):sound AudioSegment.from_file(m4a, f…...
mysql安装配置教程
由于您可能需要针对特定操作系统(如Windows、macOS或Linux)的MySQL安装配置教程,这里我将提供一个较为通用的指南,适用于大多数情况。如果您有特定的操作系统需求,请告诉我,我可以提供更详细的指导。 ### …...
埃文科技助力山西公共数据运营新发展
近日,郑州埃文科技有限公司(以下简称“埃文科技”)凭借“数据场景生态”的三维核心竞争力,成为山西云时代政务云技术有限公司专业领域数据类产品授权运营合作伙伴。 埃文科技作为数据全生命周期价值建设先行者,深度赋…...
【STM32】在FreeRTOS下使用硬件SPI收发数据出现的时序耦合问题(WK2124芯片为例)
问题 STM32中在Freertos使用SPI通讯芯片 WK2124进行SPI转4串口时,接收数据为一个任务,发送数据为一个任务,切接受任务优先级更高实测发现收发一段时间(约几分钟)外扩芯片会死锁导致WK2124复位。 分析 首先ÿ…...
linux Shell编程之函数与数组(四)
目录 一. shell 函数 1. 函数的用法 (1) 两个数求和 (2) 系统资源监控并报警函数 2. 函数变量的作用范围 3. 函数的参数 4. 递归函数 二. shell 数组 (1) 获取数组长度 (2) 读取某下标赋值 (3) 数组遍历 (4) 数组切片 (5) 数组替换 (6) 数组删除 三. shell 脚本…...
4.vtk光照vtkLight
文章目录 VTK中的光照1. vtkLight 的两种类型:位置光照和方向光照2. vtkLight 的常用方法3. 方法命名风格4. vtkProp 的可见性与 vtkLight 的开关 示例 VTK中的光照 vtkLight: 用于定义一个或多个光源。每个光源可以有其颜色、位置、焦点等属性。 vtkActor: 每个vtk…...
定义AIDL 接口
目录 定义 AIDL 接口创建 .aidl 文件实现 AIDL 接口向客户端公开接口接口的版本兼容性小结1. 定义 AIDL 接口 AIDL 接口是什么? 概念 AIDL(Android 接口定义语言)用来定义跨进程通信(IPC)的接口。简单来说,它规定了客户端和服务端之间如何进行数据交换和方法调用。.aidl…...
Linux系统-scp命令--两台服务器之间传输文件
一、定义 scp是secure copy的简写,scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令,可以在linux服务器之间复制文件和目录,scp传输是加密的,可能会稍微影响一下速度。另外,scp还非常不占资源,不会提…...
Visual Studio + OpenCV C++ 安装与配置教程
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉库,广泛用于图像处理、视频分析、模式识别和机器学习等领域。它由Intel公司于1999年发起,并在2000年由Willow Garage(一个机器人研究机构)进一步开发和维护。OpenCV支持多种编程语言,包括C++、Python…...
怎么通过OPPO手机进行图片编辑?图片编辑攻略,打造专业级照片
在当今数字化时代,手机摄影已成为记录生活、分享瞬间的重要方式。而作为市场上广受欢迎的智能手机品牌之一,OPPO手机不仅在摄影硬件上表现出色,其内置的图片编辑功能也极为强大,能够满足使用者从基础调整到高级创作的各种需求。本…...
基于MFC 的链接库
1. 动态库 MFC Regular dll: ① DLL内部有一个CWinApp类全局对象(像是基于mfc的exe程序那样存在一个theApp),该CWinApp类的Initstance负责执行dll内部初始化。 ② DLL不能人为提供Dllmain函数,该函数由mfc库提供。 ③在visual studio 的工程配置中&a…...
2025.04.15【Connection】| 生信数据可视化:连接图绘制指南
文章目录 生信数据可视化:连接图绘制指南什么是连接地图?为什么使用连接地图?如何在R中创建连接地图?1. 安装和加载必要的库2. 准备数据3. 计算大圆航线的距离和方位角4. 创建连接地图 高级技巧1. 自定义地图样式2. 添加地理背景 …...
回溯算法:List 还是 ArrayList?一个深拷贝引发的思考
在学习和使用回溯算法解决问题时,我们经常会遇到需要维护一个结果列表,例如所有可能的子集、组合或排列。 这个结果列表通常是一个 List<List<Integer>>,其中内部的 List<Integer> 代表一个具体的解。 然而,在…...
WPS表格中设置折线图随数据列自动变化——存钱计划
效果展示: wps自动更新表格 1.公式>名称管理器>新建 2.修改名称和引用位置 OFFSET(Sheet1!$A$2,0,0,COUNTA(Sheet1!$A:$A)-1,1) 3.插入>图表 4.右键>选择数据 5.添加,输入名称和系列值。 Sheet1!名称管理器里的名字 标签分类里也填入 6如图…...
内网Windows挂载目录到公网服务器
工程目的 最近在研究图像生成,Stable Diffusion的各种模型尤其3.5以后大的飞起来,动不动五六十G,以往上传到服务器费时费力占带宽又占存储空间,更关键的是用学校服务器只能校园网才能上,上传传个半天第二天来一看发现…...
ffmpeg命令(一):信息查询命令
媒体文件信息查看 命令说明ffmpeg -i input.mp4查看媒体文件基本信息(封装格式、编解码器、时长等)ffprobe input.mp4使用专用工具查看详细信息ffprobe -v error -show_format -show_streams input.mp4输出格式和流的详细信息ffprobe -v quiet -print_f…...
2 cline 提示词工程指南-记忆库
cline 提示词工程指南-记忆库 前言 编程,就是搭建一个系统,该系统在编程过程中逐步长成,最后该系统可以完成某个具体任务。 显然,编程是一个需要仔细规划、逐步推进的系统性、流程性、逻辑性工作。 我们的 ai 能胜任么&#x…...
VueDOMPurifyHTML 防止 XSS(跨站脚本攻击) 风险
VueDOMPurifyHTML 是一个 Vue.js 插件,用于在 v-html 指令中安全地渲染 HTML 内容,防止 XSS(跨站脚本攻击) 风险。 作用 解决 v-html 的安全问题 Vue 的 v-html 会直接渲染原始 HTML࿰…...
关于SQLite轻量数据库的研究
安装本地SQLite 下载地址: https://www.sqlite.org/download.html 下载这两个包 解压到本地,得到这几个文件: 将解压后的目录添加到Path环境变量中: 在cmd中输入 “sqlite3” 和 “.open D:\work\sqliteInstall\mytestdb.…...
使用Python爬取豆瓣电影Top250并保存到Excel完整教程
在当今数据驱动的时代,获取和分析网络数据已成为许多领域的重要技能。本文将详细介绍如何使用Python爬取豆瓣电影Top250榜单数据,并将结果保存到Excel文件中。这个项目不仅适合Python初学者学习网络爬虫基础,也能帮助数据分析师获取有价值的电…...
Redis + Caffeine打造超速两级缓存架构
背景 接口的逻辑非常简单:根据传入的城市、仓库和发货时间,查询快递的预计送达时间。 然而,由于会频繁调用这个接口,尤其是在大促期间,接口的性能要求极高。 数据量虽然不大,但为了确保接口的高性能和高…...
讲讲String类的常用函数
String类在开发过程中经常用到,这里来总结一下。 1.声明与初始化 std::string str;//声明 std::string str "Hello, World!";//初始化 2.连接 std::string str1 "Hello, "; std::string str2 "World!"; std::string result …...
Sentinel实战教程:流量控制与Spring Boot集成
Sentinel实战教程:流量控制与Spring Boot集成 1. Sentinel简介与核心概念 1.1 什么是Sentinel? Sentinel是阿里巴巴开源的流量控制组件,主要用于微服务架构中的流量防护。它通过限流、熔断、热点防护等机制,帮助系统在高并发场景下保持稳定运行。 1.2 核心功能与术语 流…...
【计算机系统结构】MIPSsim
目录 双击MIPSsim.exe 问题1:Microsoft Defender SmartScreen阻止了无法是被的应用启动,运行此应用可能会导致你的电脑存在风险 解决 出现下面的问题的话,建议直接在官网下载 问题2:.NET Framework 3.5安装错误代码0x80240438 …...
Charles 安装与使用详解:实现 App 与小程序 HTTPS 抓包
在日常的移动端开发、接口调试或逆向分析中,我们经常需要抓取移动 App 或微信小程序的 HTTP/HTTPS 请求。Charles 是一款经典强大的代理抓包工具,凭借简单的界面和强大的功能,成为了 macOS 抓包的首选工具之一。 本文将详细介绍 Charles 的安…...
0415美团面试题目详解
基础知识型,基础知识!!! margin-top:100%(基于父元素宽度) “margin-top: 100% 表示元素的上外边距为父元素宽度的 100%。例如,若父元素宽 300px,则上边距为300px。需注意,CSS 中垂直方向的百分比边距(如 margin-top/margin-bottom)均基于父元素宽度计算,而非高度。这…...
【微信小程序】报错: http://127.0.0.1:7001 不在以下 request 合法域名列表中
问题 微信小程序报错: http://127.0.0.1:7001 不在以下 request 合法域名列表中,请参考文档:https://developers.weixin.qq.com/miniprogram/dev/framework/ability/network.html(env: Windows,mp,1.05.2204250; lib: 3.0.2) 解决方法: 详…...
go的json unmarshal和 k8s的deepcopy对比
Go 的 encoding/json.Unmarshal 和 Kubernetes 的 DeepCopy 虽然都依赖反射,但性能差异显著。以下是两者的对比分析及性能优化原理: 一、反射实现差异 1. json.Unmarshal 的反射特点 动态类型解析:需在运行时解析 JSON 结构,通过…...
1. k8s的简介
Kubernetes(k8s)简介 1. 产生背景 随着云计算和微服务架构的兴起,传统的单体应用逐渐被拆分为多个小型、松耦合的服务(微服务)。这种架构虽然提升了开发灵活性和可维护性,但也带来了新的挑战:…...
华为云CloudMatrix 384 超节点将有数万规模上线,赋能AI产业发展
近日,华为公司副总裁张修征表示,华为云 CloudMatrix 384 超节点今年上半年将有数万规模的上线,这或将彻底终结算力焦虑。未来,CloudMatrix 超节点可以构建超过万片的大集群来提供算力。 CloudMatrix 384超节点 华为云 CloudMatri…...