CN108399068B - 函数程序持久化的方法、电子设备及存储介质 - Google Patents
函数程序持久化的方法、电子设备及存储介质 Download PDFInfo
- Publication number
- CN108399068B CN108399068B CN201810174438.XA CN201810174438A CN108399068B CN 108399068 B CN108399068 B CN 108399068B CN 201810174438 A CN201810174438 A CN 201810174438A CN 108399068 B CN108399068 B CN 108399068B
- Authority
- CN
- China
- Prior art keywords
- function
- saved
- program
- needs
- code
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
- G06F8/43—Checking; Contextual analysis
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Devices For Executing Special Programs (AREA)
- Stored Programmes (AREA)
Abstract
本发明实施例涉及应用程序开发技术领域,公开了一种函数程序持久化的方法、电子设备及存储介质。本发明中,该方法包括:执行目标程序时,判断目标程序的函数是否需要被保存,若需要被保存,则保存需要被保存的函数的上下文环境及运行代码;其中,被保存的函数为具备闭包恢复过程的持久化编译函数;判断是否需要恢复被保存的函数,在需要恢复被保存的函数时,读取被保存的函数的上下文环境及运行代码,并对被保存的函数进行现场编译,得到可运行的持久化编译函数;执行可运行的持久化编译函数。本发明通过自动存储函数及其闭包变量并恢复函数及其闭包变量来达到函数式程序持久化的目的,从而可极大地提高互联网应用的开发效率、降低出错率。
Description
技术领域
本发明实施例涉及应用程序开发技术领域,特别涉及一种函数程序持久化的方法、电子设备及存储介质。
背景技术
程序运行状态持久化是互联网应用开发的关键问题。一般而言互联网应用都具有复杂的业务,具有多步交互,且一项业务可能会持续很长时间。这需要互联网应用能够做到程序的持久化:如电商应用中,下单步骤会生成一个“订单”作为持久化的对象。持久化是将程序数据在持久状态和瞬时状态间转换的机制。在目前所有程序设计语言所定义的程序中,变量均属于瞬时状态,程序中断运行后该变量数据就会丢失,因而部分关键数据需要经过持久化才能维持业务的正常运转。目前相关技术还都需要开发人员自行决定哪些数据需要持久化。
当前一些程序设计语言中已具备较为成熟的持久化方案,如Java的Hibernate组件,Python中的Pickle等;这些持久化方案通过显式地对该组件进行调用来将变量写入磁盘或数据库中。虽然这些方案能够解决持久化问题,然而这些持久化方案会使得程序代码多出来一些专门用于持久化的冗余代码,此外这些方案并不能帮助开发者判断何时应将变量持久化,何时读出变量。因此这些方案虽然提供了持久化方案,但对于初级程序员而言极容易误用,对于高级程序员而言又制约他们的开发效率。
目前也有一些工具能够对程序代码自动产生持久化类。如JavaBeans、GreenDao等工具,能够根据数据库表自动创建类并交给程序员使用。这一工具解决了持久化组件的需要手工操作编写的困难。这类工具在客户端上的应用较为流行。
此外,在程序设计时时常需要对复杂的数据结构进行持久化。如多级嵌套、甚至包括循环引用的对象等。该情况是广泛存在的,如电商的店铺会对应若干商品,商品会对应买家卖家用户,而卖家又对应店铺等。对于带循环引用的数据结构持久化,也是一个必需解决的问题。目前的做法主要依靠手工设计数据库来实现,并通过外键进行关联。另外也有circular-json等可以解决循环引用的对象序列化方案从而可以对复杂对象持久化。
发明人发现现有技术中至少存在如下问题:这些持久化类通过人工定义对象的字段来自动生成数据库表、数据库操作等。这些工具相当于一种对数据库的易用性封装。这些工具虽然能够避免手工写数据库操作语句的工作,但仍然无法减轻开发者的劳动强度或降低出错率。首先这些持久化类无法对函数进行持久化。其次持久化的时机、读数据库的时机仍然要人工判断。对于复杂的服务端程序,一个业务流程会涉及到多段交互,因而需要多次存储和还原程序运行状态的代码;何时持久化、何时解变量、是否应当进入下一步仍然需要人工判断。自动产生持久化类的方案也只能是稍微减轻了开发者劳动量,并不能本质上解决存储和还原程序运行状态的问题。
数据库外键关联技术能够将具有复杂数据嵌套结构的变量以合理的方式存储在数据库中。当前流行的数据库都已经具备了外键关联技术。此外,诸如circular-json、serializer等序列化工具也具备一定的序列化。这些工具为储存复杂的程序运行状态提供了良好的底层环境。这些序列化工具本质上仍然不能对函数进行持久化,因而也无法直接解决存储和还原程序运行状态的问题。但是这些工具对于复杂对象嵌套的解析能力为对复杂的程序运行时的变量进行解析和存储提供了良好的基础。
发明内容
本发明实施方式的目的在于提供一种函数程序持久化的方法、电子设备及存储介质,通过自动存储函数及其闭包变量并恢复函数及其闭包变量来达到函数式程序持久化的目的,从而使得开发者在基于函数式程序开发互联网应用时,无需手工进行持久化操作,可极大地提高互联网应用的开发效率、降低出错率。
为解决上述技术问题,本发明的实施方式提供了一种函数程序持久化的方法,包括:执行目标程序时,判断所述目标程序的函数是否需要被保存,若需要被保存,则保存所述需要被保存的函数的上下文环境及运行代码;其中,所述被保存的函数为具备闭包恢复过程的持久化编译函数;判断是否需要恢复所述被保存的函数,在需要恢复所述被保存的函数时,读取所述被保存的函数的上下文环境及运行代码,并对所述被保存的函数进行现场编译,得到可运行的持久化编译函数;执行所述可运行的持久化编译函数。
本发明的实施方式还提供了一种电子设备,包括:至少一个处理器;以及,与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如上所述的函数程序持久化的方法。
本发明的实施方式还提供了一种计算机可读存储介质,存储有计算机程序,所述计算机程序被处理器执行时实现如上所述的函数程序持久化的方法。
本发明实施方式相对于现有技术而言,在执行目标程序时,当判断出目标程序中的函数需要被保存时,则保存该函数的上下文环境及运行代码,在需要恢复该函数时,读取保存的上下文环境以及运行代码,并进行现场编译得到可运行的持久化编译函数,继续执行该可运行的持久化编译函数即可。持久化编译函数是指与开发人员编写的函数等价的,但是自身具备闭包恢复过程的函数。因此,本发明通过存储函数及其闭包,并对函数进行现场编译,从而使得函数式程序能够自动实现持久化,进而可以大大提高互联网应用的开发效率,降低开发人员工作量以及出错率。
另外,对所述被保存的函数进行现场编译,得到可运行的持久化编译函数,具体包括:对需要被恢复的函数的运行代码进行编译得到用于生成函数对象的函数类;将保存的上下文环境中的所述需要被恢复的函数的实例传递给所述函数类,并运行所述函数类,以生成一个函数对象;递归地执行上述一个函数对象的生成步骤,直到所述需要被恢复的函数的上下文环境中的所有函数对象均被重新生成,从而提供了一种现场编译的具体实现方式。
另外,所述具备闭包恢复过程的持久化编译函数通过以下方式实现:从待持久化的原程序中提取出所有函数以及各函数的闭包;确定并记录所述各函数的上下文环境;在各所述函数中写入用于恢复所述闭包的运行代码以生成所述持久化编译函数,从而提供了一种持久化编译函数的具体实现方式。
另外,所述所述需要被保存的函数的上下文环境具体包括:需要被保存的函数的实例、所述需要被保存的函数的祖实例以及所述祖实例的运行代码,从而提供了一种函数及其闭包的具体存储方式。
另外,所述保存所述需要被保存的函数的上下文环境及运行代码,具体包括:获取所述需要被保存的函数的上下文环境及运行代码,并转换成预设格式的文件;保存所述预设格式的文件。
另外,在所述保存所述需要被保存的函数的上下文环境及运行代码中,将需要被保存的函数的实例与需要被保存的函数对象一一对应关联。
另外,判断所述目标程序的函数是否需要被保存具体为:若目标程序的函数被赋予所述目标程序中的变量,则判定所述目标程序的函数需要被保存。
附图说明
一个或多个实施例通过与之对应的附图中的图片进行示例性说明,这些示例性说明并不构成对实施例的限定,附图中具有相同参考数字标号的元件表示为类似的元件,除非有特别申明,附图中的图不构成比例限制。
图1是根据本发明第一实施方式函数程序持久化的方法的流程图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合附图对本发明的各实施方式进行详细的阐述。然而,本领域的普通技术人员可以理解,在本发明各实施方式中,为了使读者更好地理解本申请而提出了许多技术细节。但是,即使没有这些技术细节和基于以下各实施方式的种种变化和修改,也可以实现本申请所要求保护的技术方案。
函数式编程的开发效率较高,然而主流函数式编程工具在网络、多机交互等环境上只能传递普通对象而无法传递函数对象,因此函数式编程方法失效。针对现有函数式程序持久化中存在的需要人工决定持久化哪些变量、指定持久化时机、编写准许重入判断、变量恢复函数等的繁琐复杂操作,本发明通过自动生成持久化程序代码,使得函数对象能够持久化并传递,从而使得函数式编程方法仍然有效,并且使得程序中断、升级后,原有业务流程可以继续运行,因此能够提高开发效率。
本发明的技术构思是:首先通过编译器将开发者给出的需要持久化运行的程序转义为通过本方案运行环境可执行的代码,然后将本方案运行环境和编译后的代码进一步和开发者的其他程序组件混合,达到持久化运行的效果。如开发者在开发互联网App时,可用本方案编写业务逻辑的处理程序,然后使用编译后的代码和通用的网络库对接,生成完整的代码。
本发明实施例中,实现持久化功能时包括以下组件:
函数对象库:用于记录函数对象标识符、该函数对象对应的函数名称和对应的实例的外部数据库;
运行实例库:用于记录实例对象标识符和储存的闭包的外部数据库;
构造函数:构造实例对象时,需要给出父实例;
储存的闭包:是一个键值对,代表一个函数所创建的临时变量和临时变量的值;
获取闭包操作:对自身和祖实例(父实例和父实例的父实例等等)所储存的闭包进行合并操作,儿子实例所存储的闭包中包含的键值对能够覆盖掉祖实例所储存的闭包;
存储闭包操作:提供一个键值对。自身和祖实例依次更新自身所对应的键值对并存储到运行实例库中。儿子实例存储过的键值对祖实例不再存储;
事件库:储存何时应该调用哪个函数的哪个实例,并记录事件名称、触发条件、触发的函数对象标识符,函数对象所对应的实例对象标识符;
运行环境:运行环境保持和外部数据库的连接并维护事件库和函数库。运行环境还每次执行一个函数对象,然后检查是否有事件被触发,或者程序需要关闭等。
本发明的第一实施方式涉及一种函数程序持久化的方法,其包括:执行目标程序时,判断所述目标程序的函数是否需要被保存,若需要被保存,则保存需要被保存的函数的上下文环境及运行代码,其中,被保存的函数为具备闭包恢复过程的持久化编译函数,判断是否需要恢复被保存的函数,在需要恢复被保存的函数时,读取被保存的函数的上下文环境及运行代码,并对被保存的函数进行现场编译,得到可运行的持久化编译函数,执行可运行的持久化编译函数。本发明实施方式相对于现有技术而言,在执行目标程序时,当判断出目标程序中的函数需要被保存时,则保存该函数的上下文环境及运行代码,在需要恢复该函数时,读取保存的上下文环境以及运行代码,并进行现场编译得到可运行的持久化编译函数,继续执行该可运行的持久化编译函数即可。持久化编译函数是指与开发人员编写的函数等价的,但是自身具备闭包恢复过程的函数。因此,本发明通过存储函数及其闭包,并对函数进行现场编译,从而使得函数式程序能够自动实现持久化,进而可以大大提高互联网应用的开发效率,降低开发人员工作量以及出错率。下面对本实施方式的函数程序持久化的方法的实现细节进行具体的说明,以下内容仅为方便理解提供的实现细节,并非实施本方案的必须。
请参阅图1,本实施方式中的函数程序持久化的方法包括步骤101至步骤105。
步骤101:执行目标程序时,判断目标程序的函数是否需要被保存。如果目标程序的函数是否需要被保存,则执行步骤102,如果目标程序的函数不需要被保存,则返回执行步骤101。
目标程序初始化时,连接到事件库、函数库和实例库。然后进入循环,检查事件库是否有需要被触发的事件,如果有则触发该事件,否则进入休眠。
其中,设置一个事件的步骤包括:程序代码提供一个事件名称、触发条件,以及函数,等到当前代码执行完毕,在事件库中记录事件名称、触发条件、函数对像对应的函数名称和函数对象标识符。在实例库中保存该函数对象所对应的实例。
触发一个事件的步骤包括:等待当前代码执行完毕,若事件库中某事件所记录的触发要求已满足,则执行以下步骤:根据对应的函数标识符,从函数库中找出该函数对象对应的实例的实例标识符,根据实例标识符,从实例库中找到储存的闭包,以此生成一个实例对象。根据函数对象记录的函数名称,从函数对象列表找到函数对象的构造方法,生成一个函数对象。使用找到的实例对象作为对应的实例对象。调用该函数对象的执行方法。需要说明的是,编译后的程序代码通过一个预先设定的函数使用该功能。
目标程序在执行时,对目标程序的函数的类型进行判断,在该函数被赋予给目标程序中的某个变量时,则判定该函数需要被保存,否则,判定该函数无需被保存。本实施方式对于目标程序的函数是否需要被保存的具体判断方式不作限制。
步骤102:保存需要被保存的函数的上下文环境及运行代码。
其中,被保存的函数为具备闭包恢复过程的持久化编译函数。通过编译器达到存储函数对象的目的,原理是:转码用户所编写的代码,使得每一个对上下文环境的修改都被记录下来。具体地说:具备闭包恢复过程的持久化编译函数通过以下方式实现:从待持久化的原程序中提取出所有函数以及各函数的闭包,确定并记录各函数的上下文环境,在各函数中写入用于恢复闭包的运行代码以生成持久化编译函数。换句话说,即是对需要持久化的程序做如下处理:获取需要持久化的程序,读取其中的每个函数,并找到每个函数的闭包,并对其中的每个函数执行以下操作:通过预设编译程序(亦可称为预设编译器)编写一个新函数,并对新函数的执行方法增加一个恢复闭包的过程。对于被定义在函数内的函数,预设编译器会将其改写为对预设编译器编译出来的函数的创建。其中,待持久化的原程序包括:变量以及函数。在函数式编程中,函数本身也是一种变量。一般而言,函数的运行不可被打断,当事件触发完毕等待下一个事件时可以被打断。
具体地说,由开发者提供编写好的函数式程序,函数式程序通常指通过函数式编程风格编写的事件化的程序。例如,如定义了“文件读完后”执行“A函数”即为一段函数式程序。
接下来,通过预设的编译程序对该函数式程序进行编译,在编译的过程中,首先提取出所有函数及其闭包,并由预设编译程序自动确定需要持久化的程序中的不同函数的上下文环境,并对各函数的上下文环境与各函数的对应关系进行记录,然后由预设的编译程序将各函数改写成新的对应的函数。改写后的函数与改写前的函数在功能上完全等价,但是在改写的过程中,在各函数中写入了用于存储以及恢复该函数的代码,从而使得通过预设编译程序编译后的函数成为可运行的持久化编译函数,在对需要持久化的程序中的所有函数均完成编译之后,还需要将编译后的程序与外部数据库对接,例如与通用的网络库进行对接,从而生成目标程序的完整的代码。
其中,预设编译器对用户定义的函数的改写,主要就是让函数自己给自己一个标识符,另外就是把特定代码写在用户定义的函数里,特定代码用于把函数的上下文环境保存下来。然后特定代码在存储和恢复时会循环执行。其中,执行特定代码的时候,若是用于恢复,就恢复函数对象,恢复完成时,遇到定义的需要保存的函数对象,则会保存它。
其中,预设编译器还用于确定用户定义的函数对象的上下文环境,然后给每个函数赋值标识符,并记录下来。只有经过预设编译器编译的函数才能够被持久化。
下面对本实施例的持久化编译函数的生成过程详细说明如下:预设编译器获取用户定义的原程序,对原程序中出现的所有函数进行自动命名,对每个函数,生成一个新函数,即对原函数进行重新改写,使得该函数的函数对象的构造函数接受一个实例标识符(ID),并具有执行方法。对每个声明函数的语句,改写成使用当前函数上下文(函数实际运行时才会被决定),对预设编译器新写的对应函数进行构造(例如在每个函数的开始位置增加构造函数代码),构造函数的代码在函数运行时才会被执行。对每个函数调用的语句,改写成对应函数对象的对执行方法的调用。生成一个函数对象列表,记录所有函数名称和函数对象的构造方法的对应关系。其中,函数需要上下文才能执行。函数对象是将这些函数“可执行化”。
其中,构造函数在构造函数对象时,首先接受一个函数实例作为父实例并关联该实例,然后创造一个子实例作为该函数对象的运行实例。函数对象也记录了该函数对象所对应的函数的函数名称。其中,函数是一段代码,但该代码在没有指定上下文(即父实例)时不能运行。函数对象则具有上下文(父实例),可以运行。函数对象的“执行”(The executionof a function object)是实例。
函数对象的执行方法首先对函数运行环境中出现的闭包变量进行初始化,并设置一个不会直接被函数代码所访问的“特殊变量”,使得生成的函数可以访问实例对象。然后执行实际的函数代码。执行完毕后,检查所有闭包变量的更改并更新到该函数对象所对应的运行实例库中。最后检查该函数对象所对应的运行实例是否还被其它函数对象或运行实例所引用,若无引用则删除对应的运行实例。最后检查该函数对象是否还被其他实例所关联或存在于其它实例的储存的闭包中,若无则删除该对象。删除函数对象时,递归地检查父实例是否还被其它函数对象或运行实例引用,若无引用则删除该运行实例。
步骤102中,需要被保存的函数的上下文环境具体包括需要被保存的函数的实例、需要被保存的函数的祖实例以及祖实例的运行代码。
其中,存储一个函数对象的原理是:保存声明此函数时,正在运行的函数的实例,保存需要存储的函数的运行代码。即,保存需要被保存的函数的上下文环境及运行代码。具体地说,保存函数对象包括:获取需要被保存的函数的上下文环境及运行代码,并转换成预设格式的文件,保存预设格式的文件。其中,可以利用诸如circular-json、serializer等序列化工具将获取的需要被保存的函数的上下文环境转换成预设格式的文件,预设格式的文件即能够被外部数据库保存的文件格式的任意一种,例如数字、文本以及字符串等,本实施方式对其不作具体限制。然后将保存为预设格式的文件存储到外部数据库中,数据库存储方法为本领域技术人员所熟知,此处不再赘述。
本实施例中,需要被保存的函数的上下文环境是指恢复该函数时所需要的上下文环境。该上下文环境包括需要被保存的函数(亦可成当前函数)的实例,其中,当前函数的实例里面存在一个父实例,父实例也可以包含一些变量,这些变量对应的对象是函数对象,这些函数对象的实例也需要一并保存。
需要说明的是,在保存函数的上下文环境时,需要将函数的函数对象与函数的实例一一对应关联起来,具体地,可以通过对函数对象以及函数的实例设置对应的标识符的方式来实现。
步骤103:判断是否需要恢复被保存的函数,在需要恢复被保存的函数时,则执行步骤104,否则返回步骤103。
本实施例中,经过预设编译器编译后的所有函数均无法运行,只有在被触发时,函数对象才能运行,即目标程序执行时必须要触发一个事件,做一个恢复函数对象的操作,用户定义的代码才能继续运行。具体地说,目标程序在执行时,会将保存的函数设置为事件,该事件具有触发条件,触发条件可以从开发者提供的待持久化的程序中提取。当满足事件的触发条件时,即可判断为需要恢复被保存的函数。
步骤104:读取被保存的函数的上下文环境及运行代码,并对被保存的函数进行现场编译,得到可运行的持久化编译函数。
其中,恢复一个函数对象的原理是:找到函数运行的上下文环境,读取函数运行的代码,执行一段程序(构造函数),这段程序在函数运行的上下文环境中,使用函数运行的代码生成一个函数对象,上述步骤亦称为现场编译。
具体而言,步骤104中,对需要被恢复的函数的运行代码进行编译得到用于生成函数对象的函数类,将保存的上下文环境中的需要被恢复的函数的实例传递给该函数类,并运行该函数类,以生成一个函数对象,以上为生成一个函数对象的具体步骤。递归地执行上述一个函数对象的生成步骤,直到需要被恢复的函数的上下文环境中的所有函数对象均被重新生成。
换句话说,在恢复函数对象时,从外部数据库读取出来的内容包括:实例以及函数的运行代码。先编译一个函数类,然后再把实例作为参数传递给函数类,执行函数类以构造函数,构造完成得到一个函数对象,在构造的过程中,函数对象的生成需要涉及到构造其他的函数类时,则递归地执行上述函数对象的构造过程。
其中,读取的实例包括函数对象以及实例里的一些变量。读取出来的函数的运行代码为用于生成函数的函数,执行该生成函数的函数,在该生成函数的函数执行时,需要传递给其一个实例作为参数,因此,就需要先恢复该实例,若在恢复该实例时,该实例的变量为普通变量,则可以立刻恢复,若该实例的变量对应的是一个函数对象,则需要递归地创建这个函数对象,以恢复该实例所引用的函数对象,直到所有需被恢复的函数对象均被重新生成。
本实施例中,现场编译的运行过程为:从外部数据库读取的一段代码(即用于生成函数的函数,亦可称为构造函数),该构造函数加载需要被恢复的函数的上下文,加载该函数的运行代码,然后初始化(即构造函数运行一遍),也就是声明一遍,就可使用动态语言进行现场编译。
步骤105:执行可运行的持久化编译函数。
其中,事件被触发时就需要恢复一个函数对象,该函数对象可以是用户定义的主程序,主程序也是一个函数,也会被持久化,执行主程序这个函数时,先找到主程序所对应的上下文以及主程序里面的代码,编译这些代码,对上下文以及函数的代码进行初始化,以完成现场编译,现场编译完之后,继续执行编译好的代码。
在执行上述主程序时,若该主程序里面定义了若干个其他的函数,此时就涉及到存储函数对象。具体地,保存一下当前函数要运行的时候所需要的上下文,例如main()函数里面定义了A函数,这样,A函数的上下文环境就包含Main函数的上下文环境,以及main函数在执行时额外产生的上下文环境,这就是A函数的一个上下文环境。
本发明实施方式相对于现有技术而言,在执行目标程序时,当判断出目标程序中的函数需要被保存时,则保存该函数的上下文环境及运行代码,在需要恢复该函数时,读取保存的上下文环境以及运行代码,并进行现场编译得到可运行的持久化编译函数,继续执行该可运行的持久化编译函数即可。持久化编译函数是指与开发人员编写的函数等价的,但是自身具备闭包恢复过程的函数。因此,本发明通过存储函数及其闭包,并对函数进行现场编译,从而使得函数式程序能够自动实现持久化,进而可以大大提高互联网应用的开发效率,降低开发人员工作量以及出错率。
上面各种方法的步骤划分,只是为了描述清楚,实现时可以合并为一个步骤或者对某些步骤进行拆分,分解为多个步骤,只要包括相同的逻辑关系,都在本专利的保护范围内;对算法中或者流程中添加无关紧要的修改或者引入无关紧要的设计,但不改变其算法和流程的核心设计都在该专利的保护范围内。
本发明第二实施方式涉及一种电子设备。该电子设备包括:至少一个处理器,以及与该至少一个处理器通信连接的存储器,其中,存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行如第一实施方式所述的函数程序持久化的方法。
其中,存储器和处理器采用总线方式连接,总线可以包括任意数量的互联的总线和桥,总线将一个或多个处理器和存储器的各种电路连接在一起。总线还可以将诸如外围设备、稳压器和功率管理电路等之类的各种其他电路连接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口在总线和收发机之间提供接口。收发机可以是一个元件,也可以是多个元件,比如多个接收器和发送器,提供用于在传输介质上与各种其他装置通信的单元。经处理器处理的数据通过天线在无线介质上进行传输,进一步,天线还接收数据并将数据传送给处理器。
处理器负责管理总线和通常的处理,还可以提供各种功能,包括定时,外围接口,电压调节、电源管理以及其他控制功能。而存储器可以被用于存储处理器在执行操作时所使用的数据。
本发明第三实施方式涉及一种存储介质,存储有计算机程序。计算机程序被处理器执行时实现上述方法实施例。
即,本领域技术人员可以理解,实现上述实施例方法中的全部或部分步骤是可以通过程序来指令相关的硬件来完成,该程序存储在一个存储介质中,包括若干指令用以使得一个设备(可以是单片机,芯片等)或处理器(processor)执行本申请各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
本领域的普通技术人员可以理解,上述各实施方式是实现本发明的具体实施例,而在实际应用中,可以在形式上和细节上对其作各种改变,而不偏离本发明的精神和范围。
Claims (7)
1.一种函数程序持久化的方法,其特征在于,包括:
执行目标程序时,判断所述目标程序的函数是否需要被保存,若需要被保存,则保存所述需要被保存的函数的上下文环境及运行代码;其中,所述被保存的函数为具备闭包恢复过程的持久化编译函数;
判断是否需要恢复所述被保存的函数,在需要恢复所述被保存的函数时,读取所述被保存的函数的上下文环境及运行代码,并对所述被保存的函数进行现场编译,得到可运行的持久化编译函数;
执行所述可运行的持久化编译函数;
其中,对所述被保存的函数进行现场编译,得到可运行的持久化编译函数,具体包括:
对需要被恢复的函数的运行代码进行编译得到用于生成函数对象的函数类;
将保存的上下文环境中的所述需要被恢复的函数的实例传递给所述函数类,并运行所述函数类,以生成一个函数对象;
递归地执行上述一个函数对象的生成步骤,直到所述需要被恢复的函数的上下文环境中的所有函数对象均被重新生成;
所述具备闭包恢复过程的持久化编译函数通过以下方式实现:
通过预设的编译程序或预设编译器从待持久化的原程序中提取出所有函数以及各函数的闭包;
确定并记录所述各函数的上下文环境;
在各所述函数中写入用于恢复所述闭包的运行代码以生成所述持久化编译函数。
2.根据权利要求1所述的函数程序持久化的方法,其特征在于,所述需要被保存的函数的上下文环境具体包括:
需要被保存的函数的实例、所述需要被保存的函数的祖实例以及所述祖实例的运行代码。
3.根据权利要求2所述的函数程序持久化的方法,其特征在于,所述保存所述需要被保存的函数的上下文环境及运行代码,具体包括:
获取所述需要被保存的函数的上下文环境及运行代码,并转换成预设格式的文件;
保存所述预设格式的文件。
4.根据权利要求3所述的函数程序持久化的方法,其特征在于,在所述保存所述需要被保存的函数的上下文环境及运行代码中,将需要被保存的函数的实例与需要被保存的函数对象一一对应关联。
5.根据权利要求1所述的函数程序持久化的方法,其特征在于,判断所述目标程序的函数是否需要被保存具体为:
若目标程序的函数被赋予所述目标程序中的变量,则判定所述目标程序的函数需要被保存。
6.一种电子设备,其特征在于,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求1至5中任一所述的函数程序持久化的方法。
7.一种计算机可读存储介质,存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现权利要求1至5中任一项所述的函数程序持久化的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810174438.XA CN108399068B (zh) | 2018-03-02 | 2018-03-02 | 函数程序持久化的方法、电子设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810174438.XA CN108399068B (zh) | 2018-03-02 | 2018-03-02 | 函数程序持久化的方法、电子设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN108399068A CN108399068A (zh) | 2018-08-14 |
CN108399068B true CN108399068B (zh) | 2021-07-02 |
Family
ID=63091739
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810174438.XA Active CN108399068B (zh) | 2018-03-02 | 2018-03-02 | 函数程序持久化的方法、电子设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108399068B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112732238B (zh) * | 2020-12-28 | 2024-02-20 | 上海微盟企业发展有限公司 | 一种基于js的执行上下文获取方法及相关装置 |
CN116126429B (zh) * | 2022-12-06 | 2023-11-17 | 谷斗科技(上海)有限公司 | 一种非数据类型对象的引用持久化及其恢复的方法 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101021791A (zh) * | 2007-03-12 | 2007-08-22 | 华为技术有限公司 | 实现分布式对象持久化的方法、装置及编译单元 |
CN102222023A (zh) * | 2010-04-15 | 2011-10-19 | 微软公司 | 异步工作流 |
CN106095600A (zh) * | 2008-10-10 | 2016-11-09 | 因特伟特公司 | 用于促进持久化应用编程接口的方法和装置 |
CN107135223A (zh) * | 2017-05-11 | 2017-09-05 | 成都四象联创科技有限公司 | 海量数据管理系统的数据持久化方法 |
CN107679108A (zh) * | 2017-09-14 | 2018-02-09 | 环球智达科技(北京)有限公司 | 一种持久化加载页面的方法 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050066302A1 (en) * | 2003-09-22 | 2005-03-24 | Codito Technologies Private Limited | Method and system for minimizing thread switching overheads and memory usage in multithreaded processing using floating threads |
US8745121B2 (en) * | 2010-06-28 | 2014-06-03 | Nokia Corporation | Method and apparatus for construction and aggregation of distributed computations |
US8516509B2 (en) * | 2011-02-08 | 2013-08-20 | BlueStripe Software, Inc. | Methods and computer program products for monitoring system calls using safely removable system function table chaining |
-
2018
- 2018-03-02 CN CN201810174438.XA patent/CN108399068B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101021791A (zh) * | 2007-03-12 | 2007-08-22 | 华为技术有限公司 | 实现分布式对象持久化的方法、装置及编译单元 |
CN106095600A (zh) * | 2008-10-10 | 2016-11-09 | 因特伟特公司 | 用于促进持久化应用编程接口的方法和装置 |
CN102222023A (zh) * | 2010-04-15 | 2011-10-19 | 微软公司 | 异步工作流 |
CN107135223A (zh) * | 2017-05-11 | 2017-09-05 | 成都四象联创科技有限公司 | 海量数据管理系统的数据持久化方法 |
CN107679108A (zh) * | 2017-09-14 | 2018-02-09 | 环球智达科技(北京)有限公司 | 一种持久化加载页面的方法 |
Non-Patent Citations (2)
Title |
---|
"Attaching instance variables to method realization1 instead of classes";W. Harrison等;《Proceedings of the 1992 International Conference on Computer Languages》;20020806;第291-299页 * |
"工作流系统的访问控制模型及其安全性分析的研究";卢亚辉;《中国博士学位论文全文数据库 信息科技辑》;20090815(第8期);I139-11 * |
Also Published As
Publication number | Publication date |
---|---|
CN108399068A (zh) | 2018-08-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7047529B2 (en) | Software installation and validation using custom actions | |
RU2439664C2 (ru) | Модель фазирования прикладной среды | |
EP0786109B1 (en) | Object-oriented system for configuration history management | |
US7162709B2 (en) | System and method for common code generation | |
US5850554A (en) | Compiler tool set for efficiently generating and easily managing multiple program versions of different types | |
US7490098B2 (en) | Apparatus, system, and method for processing hierarchical data in disparate data repositories | |
JPH08512152A (ja) | インクリメンタル生成システム | |
US20100287528A1 (en) | Systems and Methods for Modifying Code Generation Templates | |
CN111796831B (zh) | 一种多芯片兼容的编译方法和装置 | |
CN105164641A (zh) | 扩展开发环境 | |
CN103718155A (zh) | 运行时系统 | |
EP1086419A1 (en) | A method of implementing parameterized types to be compatible with existing unparameterized libraries | |
US20110126179A1 (en) | Method and System for Dynamic Patching Software Using Source Code | |
US6510551B1 (en) | System for expressing complex data relationships using simple language constructs | |
CN109408354B (zh) | 应用组件的数据处理方法和装置 | |
JPH09259153A (ja) | バッチ実行制御プログラム作成装置及び方法 | |
US8327323B2 (en) | Automatic copying by ancestor in object-oriented languages | |
US7219341B2 (en) | Code analysis for selective runtime data processing | |
CN108399068B (zh) | 函数程序持久化的方法、电子设备及存储介质 | |
CN109284222B (zh) | 软件单元、数据处理系统中的项目测试方法、装置及设备 | |
US6658660B1 (en) | System and method of automatically modifying source code for marshaling, unmarshaling and marking modified data objects | |
CN111984300B (zh) | 代码复制方法及装置、电子设备和计算机可读存储介质 | |
CN114721647A (zh) | 一种基于无代码应用开发的面向对象编程方法 | |
US7526752B1 (en) | Introspection support for generic types | |
WO2008015110A2 (en) | Methods, apparatus and computer programs for modelling computer programs |
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 |