CN112860248B - 源代码生成方法及装置 - Google Patents

源代码生成方法及装置 Download PDF

Info

Publication number
CN112860248B
CN112860248B CN201911179058.6A CN201911179058A CN112860248B CN 112860248 B CN112860248 B CN 112860248B CN 201911179058 A CN201911179058 A CN 201911179058A CN 112860248 B CN112860248 B CN 112860248B
Authority
CN
China
Prior art keywords
target
engineering
dependent
template
project
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
CN201911179058.6A
Other languages
English (en)
Other versions
CN112860248A (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 CN201911179058.6A priority Critical patent/CN112860248B/zh
Publication of CN112860248A publication Critical patent/CN112860248A/zh
Application granted granted Critical
Publication of CN112860248B publication Critical patent/CN112860248B/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/30Creation or generation of source code
    • G06F8/36Software reuse
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • G06F8/44Encoding
    • G06F8/447Target code generation
    • 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)
  • Stored Programmes (AREA)

Abstract

本发明提供了一种源代码生成方法及装置,该方法包括:获取界面指令,根据界面指令确定目标模板工程和目标依赖工程;目标模板工程包括预先配置的用于实现目标功能的源代码;目标依赖工程包括预先配置的用于确定目标模板工程的依赖关系的源代码;加载目标模板工程的基础数据和目标依赖工程的基础数据,得到加载结果;目标模板工程的基础数据是预先配置的与目标功能对应的参数;目标依赖工程的基础数据是预先配置的与依赖关系对应的参数;若加载结果中,与目标模板工程相关的目标依赖工程之间不冲突,将加载结果作为目标源代码。本发明提高了生成源代码的效率;并且,能够得到框架统一的目标源代码。

Description

源代码生成方法及装置
技术领域
本发明涉及通信技术领域,尤其是涉及一种源代码生成方法及装置。
背景技术
每次新产品和项目开发启动时候都需要重新搭建很多源代码工程。包括前端和前台以及后台等工程。这种传统生成代码工程的方法造成很多项目框架不统一,并且不利于开发效率的提高。
发明内容
本发明提供了一种源代码生成方法及装置,可以缓解每次新产品开发启动时都要重新搭建源代码工程的问题,统一项目框架,节省源代码的搭建时间,以提升开发效率。
第一方面,本发明实施例提供了一种源代码生成方法,该方法包括:获取界面指令,根据所述界面指令确定目标模板工程和目标依赖工程;所述目标模板工程包括预先配置的用于实现目标功能的源代码;所述目标依赖工程包括预先配置的用于确定所述目标模板工程的依赖关系的源代码;加载所述目标模板工程的基础数据和所述目标依赖工程的基础数据,得到加载结果;所述目标模板工程的基础数据是预先配置的与所述目标功能对应的参数;所述目标依赖工程的基础数据是预先配置的与所述依赖关系对应的参数;若所述加载结果中,与所述目标模板工程相关的所述目标依赖工程之间不冲突,将所述加载结果作为目标源代码。
第二方面,本发明实施例还提供一种源代码生成装置,该装置包括:获取模块,用于获取界面指令,根据所述界面指令确定目标模板工程和目标依赖工程;所述目标模板工程包括预先配置的用于实现目标功能的源代码;所述目标依赖工程包括预先配置的用于确定所述目标模板工程的依赖关系的源代码;加载模块,用于加载所述目标模板工程的基础数据和所述目标依赖工程的基础数据,得到加载结果;所述目标模板工程的基础数据是预先配置的与所述目标功能对应的参数;所述目标依赖工程的基础数据是预先配置的与所述依赖关系对应的参数;输出模块,用于若所述加载结果中,与所述目标模板工程相关的所述目标依赖工程之间不冲突,将所述加载结果作为目标源代码。
第三方面,本发明实施例还提供一种计算机设备,包括存储器、处理器,所述存储器中存储有可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述源代码生成方法。
第四方面,本发明实施例还提供一种具有处理器可执行的非易失的程序代码的计算机可读介质,所述程序代码使所述处理器执行上述源代码生成方法。
本发明实施例带来了以下有益效果:本发明实施例提供了一种源代码生成方案,该方案包括:首先获取界面指令,并根据界面指令从预先配置的多个模板工程和多个依赖工程中选择模板工程和目标依赖工程,其中,模板工程包括用于实现多种功能的源代码;依赖工程包括用于确定模板工程的依赖关系的源代码;之后,为目标模板工程和目标依赖工程分别加载基础数据,得到加载结果,其中,目标模板工程的基础数据是预先配置的与目标功能对应的参数;目标依赖工程的基础数据是预先配置的与依赖关系对应的参数;若加载结果中,与目标模板工程相关的目标依赖工程之间不冲突,将加载结果作为目标源代码。本发明实施例在预先配置的源代码中确定目标模板工程和目标依赖工程,以代替重新搭建源代码工程的步骤,提高了生成源代码的效率;并且,通过对模板工程和依赖工程进行复用,能够得到框架统一的目标源代码。
本发明的其他特征和优点将在随后的说明书中阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明而了解。本发明的目的和其他优点在说明书、权利要求书以及附图中所特别指出的结构来实现和获得。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本发明具体实施方式或现有技术中的技术方案,下面将对具体实施方式或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的源代码生成流程图;
图2为本发明实施例提供的源代码生成执行过程示意图;
图3为本发明实施例提供的一种源代码生成装置结构框图;
图4为本发明实施例提供的另一种源代码生成装置结构框图;
图5为本发明实施例提供的计算机设备结构框图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合附图对本发明的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
目前,随着公司项目越来愈多,项目基本都是分布式JAVA框架、NODEJS前端框架以及后台脚本工程开发。开发人员每次开发项目,都需要重新搭建很多分布式工程和添加依赖工程,造成项目启动过程耽误时间,而影响项目工期。
基于此,本发明实施例提供的一种源代码生成方法及装置,可以解决基础工程和依赖快速生成和快速导出的问题,从而提升开发效率。
为便于对本实施例进行理解,首先对本发明实施例所公开的一种源代码生成方法进行详细介绍。
本发明实施例提供了一种源代码生成方法,参见图1所示的一种源代码生成方法流程图,该方法包括以下步骤:
步骤S102,获取界面指令,根据界面指令确定目标模板工程和目标依赖工程。
在本发明实施例中,界面指令包括用户选择的目标模板工程和目标依赖工程等信息。用户根据实际需求通过界面指令在多个预先配置的模板工程和多个依赖工程中选择需要的工程作为标模板工程或目标依赖工程。能够实现某种功能的源代码可以作为一个模板工程,能够用于确定模板工程的依赖关系的源代码,可以作为一个依赖工程。
需要说明的是,依赖关系可以用于确定模板工程之间的继承关系,例如,模板工程A中的部分源代码与模板工程B中的部分源代码相同,或者根据模块工程B中的部分源代码进行修改、删除或补充得到模板工程A中的源代码,那么可以说模板工程A依赖于模板工程B,二者存在依赖关系。
另外需要说的是,在本发明实施例中,可以选择多个目标模板工程,也可以选择多个目标依赖工程。
步骤S104,加载目标模板工程的基础数据和目标依赖工程的基础数据,得到加载结果。
在本发明实施例中,目标模板工程的基础数据是预先配置的与目标模板工程中的目标功能对应的参数,目标依赖工程的基础数据是预先配置的与目标依赖工程中的依赖关系对应的参数。在确定了目标模板工程和目标依赖工程之后,将目标模板工程的基础数据和目标依赖工程的基础数据分别加载到目标模板工程和目标依赖工程中,得到加载结果。
需要说明的是,可以通过framemark模板得到加载结果。
步骤S106,若加载结果中,与目标模板工程相关的目标依赖工程之间不冲突,将加载结果作为目标源代码。
在本发明实施例中,与目标模板工程相关的目标依赖工程,是用于确定该目标模板工程与其他目标模板工程之间关系的目标依赖工程;一个目标模板工程可能需要多个目标依赖工程,以确定与不同目标模板工程之间的依赖关系。
得到加载结果之后,与目标模板工程相关的多个目标依赖工程之间可能存在冲突,例如,在目标依赖工程1中,目标模板工程A,依赖于目标工程B,在目标依赖工程2中,目标模板工程A,依赖于目标工程C,若目标工程B和目标工程C的同时存在会引起矛盾,则认为与目标模板工程A相关的目标依赖工程1和目标依赖工程2之间冲突。
在本发明实施例中,如果不存在冲突,可以将加载结果作为目标源代码进行输出,以使开发人员能够使用目标源代码或基于目标源代码继续进行开发。在得到目标源代码的过程中,无需重新搭建新的源代码工程,从已经搭建过的模板工程和依赖工程中进行选择的过程,替代了搭建的过程,节省了开发时间,并且,在不同的开发过程中,复用了已经搭建过的模板工程、依赖工程以及基础数据,能够使框架得到统一。
本发明实施例提供了一种源代码生成方案,该方案包括:首先获取界面指令,并根据界面指令从预先配置的多个模板工程和多个依赖工程中选择模板工程和目标依赖工程,其中,模板工程包括用于实现多种功能的源代码;依赖工程包括用于确定模板工程的依赖关系的源代码;之后,为目标模板工程和目标依赖工程分别加载基础数据,得到加载结果,其中,目标模板工程的基础数据是预先配置的与目标功能对应的参数;目标依赖工程的基础数据是预先配置的与依赖关系对应的参数;若加载结果中,与目标模板工程相关的目标依赖工程之间不冲突,将加载结果作为目标源代码。本发明实施例在预先配置的源代码中确定目标模板工程和目标依赖工程,以代替重新搭建源代码工程的步骤,提高了生成源代码的效率;并且,通过对模板工程和依赖工程进行复用,能够得到框架统一的目标源代码。
考虑到为了提升目标源代码的可用性,并保证生成目标源代码过程的自动进行,该方案还可以执行如下步骤:
若加载结果中,与目标模板工程相关的目标依赖工程之间冲突,根据预设规则删除存在冲突的目标依赖工程中的一个或多个目标依赖工程;预设规则用于确定要删除的目标依赖工程;将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
在本发明实施例中,预设规则是预先根据实际需求设置的用于决策的规则,可以用于确定要删除或要保留的目标依赖工程。如果与目标模板工程相关的目标依赖工程之间存在冲突,根据预设规则自动保留目标依赖工程,并自动删除目标依赖工程中的一个或多个与要保留的目标依赖工程产生冲突的目标依赖工程。在删除或保留目标依赖工程时,也同时删除或保留相应的基础数据。最后,将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
考虑到为了提升目标源代码的可用性,并实现对冲突目标依赖工程的选择控制,该方案还可以执行如下步骤:
若加载结果中,与目标模板工程相关的目标依赖工程之间冲突,生成依赖冲突排除通知;依赖冲突排除通知用于提示下发勾选指令;获取勾选指令,并跟据勾选指令删除存在冲突的目标依赖工程中的一个或多个目标依赖工程;将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
在本发明实施例中,为了便于对选择目标依赖过程的控制,当与目标模板工程相关的目标依赖工程之间存在冲突时,生成依赖冲突排除通知,依赖冲突排除通知用于提示用户当前存在冲突,并提示用户下发指令,用户可以通过界面下发勾选指令,之后,获取用户下发的勾选指令,并根据勾选指令确定要删除或要保留的目标依赖工程,并对要删除的目标依赖工程进行删除,在删除或保留目标依赖工程时,也同时删除或保留相应的基础数据。最后,将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
考虑到为了提高数据处理的效率,加载目标模板工程的基础数据和目标依赖工程的基础数据,可以按照如下步骤执行:
在Redis(Remote Dictionary Server,远程字典服务)数据库中加载目标模板工程的基础数据和目标依赖工程的基础数据。
在本发明实施例中,在Redis数据库中实现对目标模板工程基础数据,以及目标依赖工程基础数据的加载,可以减轻内存数据库的压力,提高计算性能。
考虑到为了便于使用目标源代码,该方法还可以包括如下步骤:
将目标源代码所在数据库的信息同步至目标数据库中。
在本发明实施例中,目标数据库可以根据实际需求进行选择或者指定,本发明实施例对此不作具体要求。目标源代码所在数据库中有与目标源代码相关的信息,在同步时,需要将与目标源代码相关信息也进行同步。
考虑到为了提高各个步骤数据处理的效率,获取界面指令之前,还可以执行如下步骤:
生成多种微服务;多种微服务至少包括:模板引擎微服务、规则引擎微服务、基础数据微服务和SQL(Structured Query Language,结构化查询语言)同步微服务中的一种或几种;将多种微服务通过注册中心进行注册;根据注册后的多种微服务执行源代码生成方法。
在本发明实施例中,可以用模板引擎微服务执行获取界面指令,并根据界面指令确定目标模板工程和目标依赖工程的步骤,可以用规则引擎微服务执行判断加载结果中,与目标模板工程相关的目标依赖工程之间是否冲突的步骤,可以用基础数据执行加载目标模板工程的基础数据和目标依赖工程的基础数据,得到加载结果的步骤,可以用SQL同步微服务执行将目标源代码所在数据库的信息同步至目标数据库中的步骤。
参见图2所示的源代码生成执行过程示意图,下面以一个具体实施例说明该方法的实施步骤。
(1)模板引擎微服务、规则引擎微服务、基础数据微服务、SQL同步微服务通过注册中心注册服务。
(2)部分固化的环境数据、工程数据、依赖关系数据等在项目启动时候调用基础数据微服务加载到Redis内存中。
(3)用户选择模板工程、填写工程名称、选择依赖架包以及基础工程后提前申请到规则引擎。
(4)规则引擎根据提交申请的预定义的语义模块编写业务决策,并接收接受申请数据输入,解释业务规则,并根据业务规则做出业务决策。
(5)业务决策后调用相应的模板引擎,替换相应变量和模板逻辑判断,生成基础模板工程。
(6)完成基础模板工程后调用SQL同步微服务,创建数据库和同步SQL语句到项目数据库中。
(7)开发人员导入基础数据模板,开发测试。
本发明实施例提供了一种源代码生成方法及装置,该方法可以实现导出源代码工程快速进入开发,对不同项目选择不同模板工程和依赖工程,可以减轻架构师和开发人员工作量,还能够统一源代码基础工程,提升开发的效率。
本发明实施例还提供一种源代码生成装置,参见图3所示的一种源代码生成装置结构框图,该装置包括:获取模块71,用于获取界面指令,根据界面指令确定目标模板工程和目标依赖工程;目标模板工程包括预先配置的用于实现目标功能的源代码;目标依赖工程包括预先配置的用于确定目标模板工程的依赖关系的源代码;加载模块72,用于加载目标模板工程的基础数据和目标依赖工程的基础数据,得到加载结果;目标模板工程的基础数据是预先配置的与目标功能对应的参数;目标依赖工程的基础数据是预先配置的与依赖关系对应的参数;输出模块73,用于若加载结果中,与目标模板工程相关的目标依赖工程之间不冲突,将加载结果作为目标源代码。
在一个实施例中,输出模块,还用于:若加载结果中,与目标模板工程相关的目标依赖工程之间冲突,根据预设规则删除存在冲突的目标依赖工程中的一个或多个目标依赖工程;预设规则用于确定要删除的目标依赖工程;将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
在一个实施例中,输出模块,还用于:若加载结果中,与目标模板工程相关的目标依赖工程之间冲突,生成依赖冲突排除通知;依赖冲突排除通知用于提示下发勾选指令;获取勾选指令,并跟据勾选指令删除存在冲突的目标依赖工程中的一个或多个目标依赖工程;将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
在一个实施例中,加载模块,具体用于:在Redis数据库中加载目标模板工程的基础数据和目标依赖工程的基础数据。
在一个实施例中,参见图4所示的另一种源代码生成装置结构框图,该装置还包括同步模块74,具体用于:将目标源代码所在数据库的信息同步至目标数据库中。
在一个实施例中,参见图4所示的另一种源代码生成装置结构框图,该装置还包括:微服务模块75,用于:生成多种微服务;多种微服务至少包括:模板引擎微服务、规则引擎微服务、基础数据微服务和SQL同步微服务中的一种或几种;将多种微服务通过注册中心进行注册;根据注册后的多种微服务执行源代码生成方法。
本发明实施例还提供一种计算机设备,参见图5所示的计算机设备结构示意框图,该计算机设备包括存储器81、处理器82,存储器中存储有可在处理器上运行的计算机程序,处理器执行计算机程序时实现上述任一种方法的步骤。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的计算机设备的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述
本发明实施例还提供一种具有处理器可执行的非易失的程序代码的计算机可读介质,程序代码使处理器执行上述任一种方法的步骤。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
最后应说明的是:以上所述实施例,仅为本发明的具体实施方式,用以说明本发明的技术方案,而非对其限制,本发明的保护范围并不局限于此,尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,其依然可以对前述实施例所记载的技术方案进行修改或可轻易想到变化,或者对其中部分技术特征进行等同替换;而这些修改、变化或者替换,并不使相应技术方案的本质脱离本发明实施例技术方案的精神和范围,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。

Claims (9)

1.一种源代码生成方法,其特征在于,包括:
获取界面指令,根据所述界面指令确定目标模板工程和目标依赖工程;所述目标模板工程包括预先配置的用于实现目标功能的源代码;所述目标依赖工程包括预先配置的用于确定所述目标模板工程的依赖关系的源代码;依赖关系用于确定模板工程之间的继承关系;与目标模板工程相关的目标依赖工程,是用于确定该目标模板工程与其他目标模板工程之间关系的目标依赖工程;
加载所述目标模板工程的基础数据和所述目标依赖工程的基础数据,得到加载结果;所述目标模板工程的基础数据是预先配置的与所述目标功能对应的参数;所述目标依赖工程的基础数据是预先配置的与所述依赖关系对应的参数;
若所述加载结果中,与所述目标模板工程相关的所述目标依赖工程之间不冲突,将所述加载结果作为目标源代码;
还包括:若所述加载结果中,与所述目标模板工程相关的所述目标依赖工程之间冲突,根据预设规则删除存在冲突的目标依赖工程中的一个或多个目标依赖工程;所述预设规则用于确定要删除的目标依赖工程;将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
2.根据权利要求1所述的方法,其特征在于,还包括:
若所述加载结果中,与所述目标模板工程相关的所述目标依赖工程之间冲突,生成依赖冲突排除通知;所述依赖冲突排除通知用于提示下发勾选指令;
获取勾选指令,并根据所述勾选指令删除存在冲突的目标依赖工程中的一个或多个目标依赖工程;
将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
3.根据权利要求1所述的方法,其特征在于,加载所述目标模板工程的基础数据和所述目标依赖工程的基础数据,包括:
在Redis数据库中加载所述目标模板工程的基础数据和所述目标依赖工程的基础数据。
4.根据权利要求1所述的方法,其特征在于,还包括:
将所述目标源代码所在数据库的信息同步至目标数据库中。
5.根据权利要求1-4任一项所述的方法,其特征在于,获取界面指令之前,还包括:
生成多种微服务;所述多种微服务至少包括:模板引擎微服务、规则引擎微服务、基础数据微服务和SQL同步微服务中的一种或几种;
将所述多种微服务通过注册中心进行注册;
根据注册后的多种微服务执行所述源代码生成方法。
6.一种源代码生成装置,其特征在于,包括:
获取模块,用于获取界面指令,根据所述界面指令确定目标模板工程和目标依赖工程;所述目标模板工程包括预先配置的用于实现目标功能的源代码;所述目标依赖工程包括预先配置的用于确定所述目标模板工程的依赖关系的源代码;依赖关系用于确定模板工程之间的继承关系;与目标模板工程相关的目标依赖工程,是用于确定该目标模板工程与其他目标模板工程之间关系的目标依赖工程;
加载模块,用于加载所述目标模板工程的基础数据和所述目标依赖工程的基础数据,得到加载结果;所述目标模板工程的基础数据是预先配置的与所述目标功能对应的参数;所述目标依赖工程的基础数据是预先配置的与所述依赖关系对应的参数;
输出模块,用于若所述加载结果中,与所述目标模板工程相关的所述目标依赖工程之间不冲突,将所述加载结果作为目标源代码;
输出模块,还用于:若加载结果中,与目标模板工程相关的目标依赖工程之间冲突,根据预设规则删除存在冲突的目标依赖工程中的一个或多个目标依赖工程;预设规则用于确定要删除的目标依赖工程;将删除了一个或多个目标依赖工程的加载结果作为目标源代码。
7.根据权利要求6所述的装置,其特征在于,还包括微服务模块,用于:
生成多种微服务;所述多种微服务至少包括:模板引擎微服务、规则引擎微服务、基础数据微服务和SQL同步微服务中的一种或几种;
将所述多种微服务通过注册中心进行注册;
根据注册后的多种微服务执行源代码生成方法。
8.一种计算机设备,包括存储器、处理器,所述存储器中存储有可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现上述权利要求1至5任一项所述的方法的步骤。
9.一种具有处理器可执行的非易失的程序代码的计算机可读介质,其特征在于,所述程序代码使所述处理器执行上述权利要求1至5任一项所述的方法。
CN201911179058.6A 2019-11-27 2019-11-27 源代码生成方法及装置 Active CN112860248B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911179058.6A CN112860248B (zh) 2019-11-27 2019-11-27 源代码生成方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911179058.6A CN112860248B (zh) 2019-11-27 2019-11-27 源代码生成方法及装置

Publications (2)

Publication Number Publication Date
CN112860248A CN112860248A (zh) 2021-05-28
CN112860248B true CN112860248B (zh) 2023-12-05

Family

ID=75984841

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911179058.6A Active CN112860248B (zh) 2019-11-27 2019-11-27 源代码生成方法及装置

Country Status (1)

Country Link
CN (1) CN112860248B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115167834B (zh) * 2022-09-08 2022-12-23 杭州新中大科技股份有限公司 一种基于代码数据化的源代码自动生成方法及装置

Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102231104A (zh) * 2010-07-29 2011-11-02 艾默生网络能源有限公司 一种基于描述的界面生成装置及生成方法
WO2013156825A1 (en) * 2012-04-20 2013-10-24 Freescale Semiconductor, Inc. A computer system and a method for generating an optimized program code
CN103473108A (zh) * 2013-08-12 2013-12-25 福建富士通信息软件有限公司 一种Java代码生成方法
CN105893013A (zh) * 2015-12-07 2016-08-24 乐视云计算有限公司 工程构建系统及其构建方法
CN106445556A (zh) * 2016-10-18 2017-02-22 中国银行股份有限公司 一种可视化代码生成方法及系统
CN108073501A (zh) * 2016-11-14 2018-05-25 阿里巴巴集团控股有限公司 一种代码冲突检测方法及设备
CN108153897A (zh) * 2018-01-10 2018-06-12 中国银行股份有限公司 一种plsql程序代码生成方法及系统
CN108255489A (zh) * 2018-01-12 2018-07-06 北京三快在线科技有限公司 前端界面代码生成方法、装置、电子设备及存储介质
CN109062568A (zh) * 2018-06-19 2018-12-21 链家网(北京)科技有限公司 一种项目生成方法及工具
CN109614097A (zh) * 2018-12-07 2019-04-12 北京金山云网络技术有限公司 平台代码的生成方法、装置及服务器
CN110134380A (zh) * 2019-03-29 2019-08-16 北京车和家信息技术有限公司 一种基于模板引擎的代码生成方法、装置及电子设备
CN110442329A (zh) * 2019-06-26 2019-11-12 平安科技(深圳)有限公司 代码段的生成方法、装置、存储介质及计算机设备

Patent Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102231104A (zh) * 2010-07-29 2011-11-02 艾默生网络能源有限公司 一种基于描述的界面生成装置及生成方法
WO2013156825A1 (en) * 2012-04-20 2013-10-24 Freescale Semiconductor, Inc. A computer system and a method for generating an optimized program code
CN103473108A (zh) * 2013-08-12 2013-12-25 福建富士通信息软件有限公司 一种Java代码生成方法
CN105893013A (zh) * 2015-12-07 2016-08-24 乐视云计算有限公司 工程构建系统及其构建方法
CN106445556A (zh) * 2016-10-18 2017-02-22 中国银行股份有限公司 一种可视化代码生成方法及系统
CN108073501A (zh) * 2016-11-14 2018-05-25 阿里巴巴集团控股有限公司 一种代码冲突检测方法及设备
CN108153897A (zh) * 2018-01-10 2018-06-12 中国银行股份有限公司 一种plsql程序代码生成方法及系统
CN108255489A (zh) * 2018-01-12 2018-07-06 北京三快在线科技有限公司 前端界面代码生成方法、装置、电子设备及存储介质
CN109062568A (zh) * 2018-06-19 2018-12-21 链家网(北京)科技有限公司 一种项目生成方法及工具
CN109614097A (zh) * 2018-12-07 2019-04-12 北京金山云网络技术有限公司 平台代码的生成方法、装置及服务器
CN110134380A (zh) * 2019-03-29 2019-08-16 北京车和家信息技术有限公司 一种基于模板引擎的代码生成方法、装置及电子设备
CN110442329A (zh) * 2019-06-26 2019-11-12 平安科技(深圳)有限公司 代码段的生成方法、装置、存储介质及计算机设备

Also Published As

Publication number Publication date
CN112860248A (zh) 2021-05-28

Similar Documents

Publication Publication Date Title
CN110609675B (zh) 一种工作流建模方法、装置和计算机可读存储介质
CN107766050B (zh) 一种异构应用的部署方法以及装置
CN100543701C (zh) 一种实现嵌入式软件异常测试的方法及系统
CN110147225A (zh) 一种代码生成方法、装置及计算机设备、存储介质
CN106775744B (zh) 一种生成静态库的方法和装置
CN111104103B (zh) 一种软件编辑微服务的可视化方法及系统
CN107766130B (zh) 虚拟机向容器迁移的方法和装置
CN110764839A (zh) 一种业务处理流程配置方法、业务请求处理方法及装置
CN111736884B (zh) 组件化方法和系统
CN110955410A (zh) 一种代码自动生成方法、装置、设备及介质
WO2019000629A1 (zh) 多数据源数据同步方法、系统、应用服务器及计算机可读存储介质
CN111679852A (zh) 一种冲突依赖库的检测方法及装置
CN106484452B (zh) 一种软件平台的统一配置管理方法和装置
CN112860248B (zh) 源代码生成方法及装置
CN112114896A (zh) 一种插件框架及业务功能扩展的方法
CN112685040B (zh) 安卓系统中界面文件的生成方法、装置、设备及存储介质
CN113760462A (zh) 一种调度自动化系统验证环境的构建方法及装置
CN113111072A (zh) 业务数据文件生成方法及装置
CN116909553A (zh) 一种页面在线开发及本地编译运行系统
CN109766125B (zh) 批次间追平冲突的识别方法及装置
CN110866012A (zh) 表结构管理方法、装置、服务器及可读存储介质
CN112464596B (zh) 回归测试方法、系统、设备及可读存储介质
CN112256978B (zh) 一种基于数据模型的数据处理方法、装置、介质
CN110599112A (zh) 一种网络页面开发、维护方法和装置
CN111124386B (zh) 基于Unity的动画事件处理方法、装置、设备和存储介质

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