CN112825031B - 基于json格式的流程描述方法及装置 - Google Patents

基于json格式的流程描述方法及装置 Download PDF

Info

Publication number
CN112825031B
CN112825031B CN201911147923.9A CN201911147923A CN112825031B CN 112825031 B CN112825031 B CN 112825031B CN 201911147923 A CN201911147923 A CN 201911147923A CN 112825031 B CN112825031 B CN 112825031B
Authority
CN
China
Prior art keywords
flow
task
format
json
model
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201911147923.9A
Other languages
English (en)
Other versions
CN112825031A (zh
Inventor
符凯
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Unihub China Information Technology Co Ltd
Original Assignee
Unihub China Information Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Unihub China Information Technology Co Ltd filed Critical Unihub China Information Technology Co Ltd
Priority to CN201911147923.9A priority Critical patent/CN112825031B/zh
Publication of CN112825031A publication Critical patent/CN112825031A/zh
Application granted granted Critical
Publication of CN112825031B publication Critical patent/CN112825031B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/20Software design
    • G06F8/24Object-oriented
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/31Programming languages or programming paradigms
    • G06F8/315Object-oriented languages
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computing Systems (AREA)
  • Stored Programmes (AREA)

Abstract

本发明公开了一种基于JSON格式的流程描述方法及装置,该方法包括:获取任务流程中的多个任务信息;判断多个任务信息之间的顺序关系;根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型;利用流程模型对任务流程进行描述。本发明可以在保证任务流程描述清楚的前提下,对任务流程的描述进行简化,提高工作效率,降低作业成本。

Description

基于JSON格式的流程描述方法及装置
技术领域
本发明涉及计算机技术领域,尤其涉及一种基于JSON格式的流程描述方法及装置。
背景技术
流程处理是软件开发中的一种常见模式,在现有技术中,一般通过业务流程建模与标注(Business Process Modeling Notation,简称BPMN)对流程进行描述,但是BPMN的规则比较复杂,主要用于比较复杂的工作场景。对于一些简单的工作场景,这样的方法会降低工作效率,增加作业成本。举例来说,附图5提供了一种用BPMN表示的任务流程图,如附图5所示,该任务流程具体为:先执行任务A,再执行任务B和任务C,最后执行任务D,其中,任务B和任务C为并行任务。可以看出,此附图中共涉及4个节点,6条连接线和2个并行网关,对任务流程描述的较为复杂。
发明内容
本发明实施例提供一种基于JSON格式的流程描述方法,用以在保证任务流程描述清楚的前提下,对任务流程的描述进行简化,提高工作效率,降低作业成本,该方法包括:
获取任务流程中的多个任务信息;
判断多个任务信息之间的顺序关系;
根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型;
利用流程模型对任务流程进行描述;
其中,建立流程模型包括:
逆向流程使用和正向流程同样的定义方式;
还包括:
遍历流程模型,判断流程模型中是否存在事务流程,如果存在,则在事务流程中的流程节点遍历失败时,对事务流程进行回滚处理;
逆向流程使用和正向流程同样的定义方式,包括:
在定义流程的时候,需要执行回滚操作的流程需要用事务单元关键字标识;
在执行逆向流程时,对流程定义JSON对象进行遍历;
所述JSON对象是并列对象时,并行执行流程定义的函数的回滚函数;
所述JSON对象是数组时,逆序执行流程函数对应的回滚函数。
可选的,JSON格式包括:对象格式和数组格式;
根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型,包括:
判断多个任务信息之间是否存在顺序关系,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,建立流程模型。
可选的,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,包括:
若判断结果为多个任务信息之间存在顺序关系,则根据数组格式描述任务流程中的串行结构;
否则,根据对象格式描述任务流程中的并行结构。
本发明实施例还提供一种基于JSON格式的流程描述装置,用以在保证任务流程描述清楚的前提下,对任务流程的描述进行简化,提高工作效率,降低作业成本,该装置包括:
信息获取模块,用于获取任务流程中的多个任务信息;
判断模块,用于判断多个任务信息之间的顺序关系;
模型建立模块,用于根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型;
描述模块,用于利用流程模型对任务流程进行描述;
其中,模型建立模块具体用于:
逆向流程使用和正向流程同样的定义方式;
还包括回滚模块,具体用于:
遍历流程模型,判断流程模型中是否存在事务流程,如果存在,则在事务流程中的流程节点遍历失败时,对事务流程进行回滚处理;
模型建立模块具体用于:
在定义流程的时候,需要执行回滚操作的流程需要用事务单元关键字标识,逆向流程使用和正向流程同样的定义方式;
在执行逆向流程时,对流程定义JSON对象进行遍历;
所述JSON对象是并列对象时,并行执行流程定义的函数的回滚函数;
所述JSON对象是数组时,逆序执行流程函数对应的回滚函数。
可选的,JSON格式包括:对象格式和数组格式;
模型建立模块进一步用于:
判断多个任务信息之间是否存在顺序关系,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,建立流程模型。
可选的,模型建立模块进一步用于:
若判断结果为多个任务信息之间存在顺序关系,则根据数组格式描述任务流程中的串行结构;
否则,根据对象格式描述任务流程中的并行结构。
本发明实施例还提供一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述方法。
本发明实施例还提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现上述方法。
本发明实施例中,通过获取任务流程中的多个任务信息,获取任务流程中的多个任务信息,再根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型,利用流程模型对任务流程进行描述,在保证任务流程描述清楚的前提下,对任务流程的描述进行了简化,提高了工作效率,降低了作业成本。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。在附图中:
图1为本发明实施例中基于JSON格式的流程描述方法的流程图;
图2为本发明实施例中基于JSON格式的流程描述方法的另一流程图;
图3为本发明实施例中基于JSON格式的流程描述装置的结构示意图;
图4为本发明实施例中基于JSON格式的流程描述装置的另一结构示意图;
图5为现有技术的任务流程示例图;
图6为相比于图5,使用本发明实施例提供的基于JSON格式的流程描述方法后的任务流程示例图;
图7为本发明实施例中分支流程的具体示例图;
图8为本发明实施例中基于JSON格式的流程描述方法的具体事例图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚明白,下面结合附图对本发明实施例做进一步详细说明。在此,本发明的示意性实施例及其说明用于解释本发明,但并不作为对本发明的限定。
需要说明的是,Java Script Object Notation,简称JSON,是现代软件开发中一种常见的文本,独立于语言的轻量级数据交换格式,可以表示各类复杂的数据类型。
附图1为本发明实施例提供的基于JSON格式的流程描述方法的流程图,如附图1所示,该方法包括:
步骤101、获取任务流程中的多个任务信息。
步骤102、判断多个任务信息之间的顺序关系。
步骤103、根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型。
在本实施例中,JSON格式包括:对象格式和数组格式;
根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型,包括:
判断多个任务信息之间是否存在顺序关系,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,建立流程模型。
进一步地,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,包括:
若判断结果为多个任务信息之间存在顺序关系,则根据数组格式描述任务流程中的串行结构;
否则,根据对象格式描述任务流程中的并行结构。
具体实施时,对象格式是使用大括号“{}”括起来的,大括号内是由0个或多个用英文逗号分隔的“关键字:值”对(key:value)构成的,值可以是字符串、对象或者数组。
数组格式是用中括号“[]”括起来,中括号内部由0个或多个以英文逗号“,”分隔的值列表组成,值可以是字符串、对象或者数组。
正如JSON可以用数组和对象两种格式来描述全部的数据结构,本发明将各种复杂或简单的流程分解为串行结构和并行结构,正好和JSON的两种格式对应。这样使用JSON格式,可以很好地作为流程描述的数字用户线路(Digital Subscriber Line,简称DSL)。
其中,对于串行结构,因为需要保证流程执行的顺序性,可以使用数组表示,利用数组元素的有序性来表示任务的执行顺序,例如[{“task”:{"串行任务A"}},{"task":{"串行任务B"}}]。
对于并行结构,不需要保证任务的执行顺序,而是同时执行,最后需要统一汇合,可以使用JSON的并列对象表示,因为对象本身并不关心顺序,例如,{“task”:{"并行任务A"},“task”:{"并行任务B"}}。
相比于现有技术附图5提供的示例,在使用本发明后的示例图可参见附图6,本发明只需要4个节点,可以节省连线的定义和并行网关的定义(即,现有技术的并行网关等要显示在最终的流程示意图中,而本发明却不用)。
由于JSON结构本身比较简单,使用JSON结构来定义流程,就不需要复杂的流程设计器,只需要通过文本编辑器,编写JSON数据结构,就可以表示出常用的流程定义。
步骤104、利用流程模型对任务流程进行描述。
由附图1可知,通过获取任务流程中的多个任务信息,获取任务流程中的多个任务信息,再根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型,利用流程模型对任务流程进行描述,在保证任务流程描述清楚的前提下,对任务流程的描述进行了简化,提高了工作效率,降低了作业成本。
附图2为本发明实施例提供的基于JSON格式的流程描述方法的另一流程图,如附图2所示,该方法还包括:
步骤201、遍历流程模型,判断流程模型中是否存在事务流程,如果存在,则在事务流程中的流程节点遍历失败时,对事务流程进行回滚处理。
下面通过多个具体示例对本发明进行说明:
对于普通的串行任务,没有事务性要求,以关键字”task”标识。其中,对于串行任务流程,存在任务之间的顺序关系,可以使用JSON的数组格式表示,每个值是一个对象,利用数组格式的顺序性来表示。例如,{"task":[{"a1":"role1","a2":"role2"]}},代表先执行动作a1,再执行动作a2。
对于普通的并行任务流程,任务之间不存在先后顺序,可以使用JSON的对象格式表示,利用对象的顺序无关性来表示。例如,{"task":{"a1":"role","a2":"role"}},代表并行执行动作a1和动作a2。
对于附图6中的复合流程,可以表示为{"task":[{"a1":"role"},{"a2":"role","a3":"role"},{"a4":"role"}]}(即上述流程模型),代表先执行动作a1,再并行执行动a2和a3,最后执行任务a4。只需要4个节点(任务)定义,不需要额外描述任务之间的串行和并行关系。
此外,对于一些特殊的任务流程,如分支流程,举例来说:
对应switch语句,可以表示为
其中,switch对象是一个特殊对象,使用swtich关键字,来代表针对条件变量A的分支条件。条件对象A可以是任意定义的变量,根据其不同的取值(A或B),分别对应后续的不同任务分支。
或者对应if-else判断语句,可以表示为
其中,if对象是一个特殊对象,使用if关键字,来表示针对表达式的分支条件。如果表达式A成立,则执行后续的分支任务A,如果表达式B成立,则执行后续的分支任务B。
附图7为分支流程的具体示例图,该附图7的分支流程表示如下:
使用以上3类对象,已经可以覆盖我们应用中的绝大多数场景。同时,还支持task对象的嵌套以及特殊对象的扩展。例如,对于少量场景,需要考虑条件变量的转换和计算,可以引入赋值对象。
{"map":{"变量1":"表达式1"}
Map作为关键字,代表一个赋值逻辑,根据表达式1的结果赋值给变量1。
对于一些特殊的场景,例如开通,有事务性的要求。在一个事务流程内,如果出现动作执行失败,要求可以自动实现流程回退。这种情况,可以通过事务单元来表示,以”tran”关键字标识。
和普通任务类似,串行事务流程可以表示为{"tran":[{"a1":"role","a2":"role"]},并行事务流程可以表示为{"tran":{"a1":"role","a2":"role"}}。
对于特别复杂的场景,可能存在多个事务单元,或者事务流程和普通流程混合的情况。这是可以通过组合流程来表示,用”process”关键字标识。例如,{"process":["p2","p3"]},表示由2个子流程串行组合,其中p2,p3可以是前面定义的普通任务流程,也可以是事务单元。
综上所述,使用基于JSON格式的表示法,能够简单紧凑地描述通用的流程,并且具有一定的语义扩展能力。使用JSON格式来描述的流程定义,更简单,更易于编写。完全可以不借助复杂的流程定义工具,直接使用简单的文本编辑器进行定义。
在流程执行阶段,需要解析设计过程生成的流程模型,并执行对应的动作。
如果采用现有技术的BPMN来描述流程,因为存在点和线的复杂关系,那么需要自行实现图的广度优先遍历算法。而使用JSON格式表示,由于JSON本质是是一个程序对象结构,无需特殊的算法支持,天然支持遍历。
各种语言都支持对JSON对象的加载和解析,通过对JSON流程对象的递归遍历,就可以实现设计流程的执行。
如果JSON对象为数组结构,则按数组顺序顺序解析值对象。
如果JSON对象为并列对象,则使用多线程或者协程技术并行解析子对象。
如果JSON对象只包含单个子对象,且子对象key为”task”,则通过反射方式执行对象value所对应的函数。例如:[{"动作A":{}},{"动作B":{},"动作C":{}},{"动作D":{}}],其可以转化为:
执行动作A();
并行执行动作B(),动作C()
等待动作B(),动作C()执行完成
执行动作D()。
如果JSON对象为单个子对象,且子对象key为”switch”,则代表一个switch形式的分支判断,孙对象的key为条件变量,根据反射方式计算条件变量的值,可以确定对应的函数。例如:
可以转化为:
Switch(条件变量A){
Case“值A”:动作A();
Case“值B”:动作B();
}。
如果JSON对象为单个子对象,且子对象key为”if”,则代表一个if-else形式的分支判断,孙对象的key为条件表达式,根据反射方式计算表达式的值,可以确定对应的函数(对应孙对象的value)。例如:
转化为:
If(表达式A==true){动作A()}
Else if(表达式B==true){动作B()}。
如果JSON对象为单个子对象,且子对象key为”map”,则代表一个赋值计算表达式,孙对象的key为变量名,孙对象的值为表达式。使用反射方式,可以计算表达式的值,并赋值给变量。例如:{"map":{"a":"b+c"},转化为赋值语句a=b+c。
如果JSON对象为组合流程,则递归执行以上操作。
综上所述,流程的解析过程基本就是JSON对象的遍历过程,而且利用对象反射极致,在流程解析的同时,就可以同时实现对流程的执行,而不需要加载到内存后再次进行内存对象到执行过程的转换,提高了流程解析执行的效率。
对于配置开通类场景,还有一个很重要的需求就是支持回退,即流程的逆向执行。这个是一般的流程引擎都不具备的功能。如果使用BPMN工具,需要另外定义一套回滚的流程。,而对于本发明来说,就不存在这一问题。
在定义流程的时候,需要执行回滚操作的流程需要用事务单元关键字”tran”标识。逆向流程可以使用和正向流程同样的定义方式,无需单独定义。我们约定函数A对应的逆向回滚函数固定命名为函数A_rev。
在执行逆向的流程的时候,和正向执行相似,仍然是对流程定义JSON对象进行遍历,如果是并列对象,则并行执行流程定义的函数的回滚函数,如果是数组,则逆序执行流程函数对应的回滚函数。
分支逻辑的处理和正向流程相同。
赋值逻辑在回滚操作中没有实际意义,可以跳过。
这样,使用同一套流程定义,流程引擎既可以支持正向流程,也可以支持逆向流程,具体可参见附图8。
基于同一发明构思,本发明实施例中还提供了一种基于JSON格式的流程描述装置,如下面的实施例所述。由于基于JSON格式的流程描述装置解决问题的原理与基于JSON格式的流程描述方法相似,因此,基于JSON格式的流程描述装置的实施可以参见基于JSON格式的流程描述方法的实施,重复之处不再赘述。以下所使用的,术语“单元”或者“模块”可以实现预定功能的软件和/或硬件的组合。尽管以下实施例所描述的装置较佳地以软件来实现,但是硬件,或者软件和硬件的组合的实现也是可能并被构想的。
附图3为本发明实施例提供的基于JSON格式的流程描述装置的结构示意图,如附图3所示,该装置包括:
信息获取模块301,用于获取任务流程中的多个任务信息。
判断模块302,用于判断多个任务信息之间的顺序关系。
模型建立模块303,用于根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型。
描述模块304,用于利用流程模型对任务流程进行描述。
在本发明实施例中,JSON格式包括:对象格式和数组格式;
模型建立模块303进一步用于:
判断多个任务信息之间是否存在顺序关系,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,建立流程模型。
在本发明实施例中,模型建立模块303进一步用于:
若判断结果为多个任务信息之间存在顺序关系,则根据数组格式描述任务流程中的串行结构;
否则,根据对象格式描述任务流程中的并行结构。
附图4为本发明实施例提供的基于JSON格式的流程描述装置的另一结构示意图,如附图4所示,该装置还包括:
回滚模块401,用于遍历流程模型,判断流程模型中是否存在事务流程,如果存在,则在事务流程中的流程节点遍历失败时,对事务流程进行回滚处理。
本发明实施例还提供了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述方法。
本发明实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有执行上述方法的计算机程序。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
以上所述的具体实施例,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施例而已,并不用于限定本发明的保护范围,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (8)

1.一种基于JSON格式的流程描述方法,其特征在于,包括:
获取任务流程中的多个任务信息;
判断多个任务信息之间的顺序关系;
根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型;
利用流程模型对任务流程进行描述;
其中,建立流程模型包括:
逆向流程使用和正向流程同样的定义方式;
还包括:
遍历流程模型,判断流程模型中是否存在事务流程,如果存在,则在事务流程中的流程节点遍历失败时,对事务流程进行回滚处理;
逆向流程使用和正向流程同样的定义方式,包括:
在定义流程的时候,需要执行回滚操作的流程需要用事务单元关键字标识;
在执行逆向流程时,对流程定义JSON对象进行遍历;
所述JSON对象是并列对象时,并行执行流程定义的函数的回滚函数;
所述JSON对象是数组时,逆序执行流程函数对应的回滚函数。
2.如权利要求1所述的方法,其特征在于,JSON格式包括:对象格式和数组格式;
根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型,包括:
判断多个任务信息之间是否存在顺序关系,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,建立流程模型。
3.如权利要求2所述的方法,其特征在于,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,包括:
若判断结果为多个任务信息之间存在顺序关系,则根据数组格式描述任务流程中的串行结构;
否则,根据对象格式描述任务流程中的并行结构。
4.一种基于JSON格式的流程描述装置,其特征在于,包括:
信息获取模块,用于获取任务流程中的多个任务信息;
判断模块,用于判断多个任务信息之间的顺序关系;
模型建立模块,用于根据多个任务信息之间的顺序关系,结合JSON格式,建立流程模型;
描述模块,用于利用流程模型对任务流程进行描述;
其中,模型建立模块具体用于:
逆向流程使用和正向流程同样的定义方式;
还包括回滚模块,具体用于:
遍历流程模型,判断流程模型中是否存在事务流程,如果存在,则在事务流程中的流程节点遍历失败时,对事务流程进行回滚处理;
模型建立模块具体用于:
在定义流程的时候,需要执行回滚操作的流程需要用事务单元关键字标识,逆向流程使用和正向流程同样的定义方式;
在执行逆向流程时,对流程定义JSON对象进行遍历;
所述JSON对象是并列对象时,并行执行流程定义的函数的回滚函数;
所述JSON对象是数组时,逆序执行流程函数对应的回滚函数。
5.如权利要求4所述的装置,其特征在于,JSON格式包括:对象格式和数组格式;
模型建立模块进一步用于:
判断多个任务信息之间是否存在顺序关系,根据判断结果,利用对象格式和数组格式描述任务流程中的串行结构和并行结构,建立流程模型。
6.如权利要求5所述的装置,其特征在于,模型建立模块进一步用于:
若判断结果为多个任务信息之间存在顺序关系,则根据数组格式描述任务流程中的串行结构;
否则,根据对象格式描述任务流程中的并行结构。
7.一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现权利要求1至3任一所述方法。
8.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现权利要求1至3任一所述方法。
CN201911147923.9A 2019-11-21 2019-11-21 基于json格式的流程描述方法及装置 Active CN112825031B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911147923.9A CN112825031B (zh) 2019-11-21 2019-11-21 基于json格式的流程描述方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911147923.9A CN112825031B (zh) 2019-11-21 2019-11-21 基于json格式的流程描述方法及装置

Publications (2)

Publication Number Publication Date
CN112825031A CN112825031A (zh) 2021-05-21
CN112825031B true CN112825031B (zh) 2024-03-12

Family

ID=75906471

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911147923.9A Active CN112825031B (zh) 2019-11-21 2019-11-21 基于json格式的流程描述方法及装置

Country Status (1)

Country Link
CN (1) CN112825031B (zh)

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004046895A (ja) * 2003-09-08 2004-02-12 Toshiba Corp ワークフロー変換方法
CN101615269A (zh) * 2009-08-11 2009-12-30 用友软件股份有限公司 一种工作流管理系统中的回退方法和装置
CN101799809A (zh) * 2009-02-10 2010-08-11 中国移动通信集团公司 数据挖掘方法和数据挖掘系统
CN103186834A (zh) * 2011-12-31 2013-07-03 阿里巴巴集团控股有限公司 业务流程配置方法和装置
CN105278960A (zh) * 2015-10-27 2016-01-27 航天恒星科技有限公司 一种遥感应用中的流程自动化方法及系统
CN106651085A (zh) * 2016-08-30 2017-05-10 东软集团股份有限公司 基于流程回退的补偿方法和装置
CN106708854A (zh) * 2015-11-13 2017-05-24 博雅网络游戏开发(深圳)有限公司 数据导出方法和装置
CN109062560A (zh) * 2018-07-25 2018-12-21 北京百度网讯科技有限公司 用于生成信息的方法和装置
CN110035103A (zh) * 2018-01-12 2019-07-19 宁波中科集成电路设计中心有限公司 一种节点间数据可传递的分布式调度系统

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060294006A1 (en) * 2005-06-28 2006-12-28 International Business Machines Corporation Business transaction process controller for composite transactions
US20080244565A1 (en) * 2007-03-29 2008-10-02 Microsoft Corporation Dynamic software installation and configuration
US20110295634A1 (en) * 2010-05-28 2011-12-01 International Business Machines Corporation System and Method for Dynamic Optimal Resource Constraint Mapping in Business Process Models

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004046895A (ja) * 2003-09-08 2004-02-12 Toshiba Corp ワークフロー変換方法
CN101799809A (zh) * 2009-02-10 2010-08-11 中国移动通信集团公司 数据挖掘方法和数据挖掘系统
CN101615269A (zh) * 2009-08-11 2009-12-30 用友软件股份有限公司 一种工作流管理系统中的回退方法和装置
CN103186834A (zh) * 2011-12-31 2013-07-03 阿里巴巴集团控股有限公司 业务流程配置方法和装置
CN105278960A (zh) * 2015-10-27 2016-01-27 航天恒星科技有限公司 一种遥感应用中的流程自动化方法及系统
CN106708854A (zh) * 2015-11-13 2017-05-24 博雅网络游戏开发(深圳)有限公司 数据导出方法和装置
CN106651085A (zh) * 2016-08-30 2017-05-10 东软集团股份有限公司 基于流程回退的补偿方法和装置
CN110035103A (zh) * 2018-01-12 2019-07-19 宁波中科集成电路设计中心有限公司 一种节点间数据可传递的分布式调度系统
CN109062560A (zh) * 2018-07-25 2018-12-21 北京百度网讯科技有限公司 用于生成信息的方法和装置

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
基于事务的工作流异常处理优化的研究与设计;崔磊;《中国优秀硕士学位论文全文数据库》(第2013年11期);I138-396 *
敏捷BPM的可视化流程模型研究与实现;龚炳江 等;《计算机应用与软件》;第30卷(第10期);第199-201页,第254页 *
科学工作流建模方法研究;孙小雅;《中国优秀硕士学位论文全文数据库》(第2019年11期);I138-13 *

Also Published As

Publication number Publication date
CN112825031A (zh) 2021-05-21

Similar Documents

Publication Publication Date Title
US9864590B2 (en) Method and system for automated improvement of parallelism in program compilation
EP3049913B1 (en) Evaluating rules applied to data
US7860863B2 (en) Optimization model for processing hierarchical data in stream systems
US8583413B2 (en) Computer method and apparatus for chaining of model-to-model transformations
US10579349B2 (en) Verification of a dataflow representation of a program through static type-checking
US8789031B2 (en) Software constructed strands for execution on a multi-core architecture
CN111897580B (zh) 一种可重构阵列处理器的指令调度系统及方法
JPH07234790A (ja) プログラム変換処理装置およびプログラム変換処理方法
CN113283613B (zh) 深度学习模型的生成方法、优化方法、装置、设备及介质
US8495593B2 (en) Method and system for state machine translation
CN108037913B (zh) xUML4MC模型到MSVL语言程序的转换方法、计算机可读存储介质
CN112214222B (zh) COStream中用于实现前馈神经网络的sequential结构及其编译方法
CN111221852A (zh) 基于大数据的混合查询处理方法及装置
CN114595580A (zh) 一种满足大型柔性叶片优化设计的复杂工作流引擎方法
CN112825031B (zh) 基于json格式的流程描述方法及装置
US20090064092A1 (en) Visual programming language optimization
CN109446146B (zh) 一种应用层通信协议的状态转换序列生成方法
CN112527304A (zh) 基于异构平台的自适应节点融合编译优化方法
CN115809294A (zh) 一种基于Spark SQL临时视图的快速ETL方法
WO2008041442A1 (fr) Procédé de création de programme par parallélisation, dispositif de création de programme par parallélisation, et programme de création de programme par parallélisation
Liu et al. A Generate-Test-Aggregate parallel programming library for systematic parallel programming
Kalenkova Application of if-conversion to verification and optimization of workflows
JP2002312167A (ja) 変数の値をコンピュータに算出させるためのプログラム、コンパイルプログラム、変数値確定方法およびプログラム生成方法
Li et al. Automatic performance diagnosis of parallel computations with compositional models
Hidders et al. Towards a calculus for collection-oriented scientific workflows with side effects

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant