CN112711420B - 一种代码转换方法及装置 - Google Patents

一种代码转换方法及装置 Download PDF

Info

Publication number
CN112711420B
CN112711420B CN201911025267.5A CN201911025267A CN112711420B CN 112711420 B CN112711420 B CN 112711420B CN 201911025267 A CN201911025267 A CN 201911025267A CN 112711420 B CN112711420 B CN 112711420B
Authority
CN
China
Prior art keywords
code
chained
mark
value
module
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
CN201911025267.5A
Other languages
English (en)
Other versions
CN112711420A (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.)
Beijing Dajia Internet Information Technology Co Ltd
Original Assignee
Beijing Dajia Internet 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 Beijing Dajia Internet Information Technology Co Ltd filed Critical Beijing Dajia Internet Information Technology Co Ltd
Priority to CN201911025267.5A priority Critical patent/CN112711420B/zh
Publication of CN112711420A publication Critical patent/CN112711420A/zh
Application granted granted Critical
Publication of CN112711420B publication Critical patent/CN112711420B/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/40Transformation of program code
    • G06F8/41Compilation
    • G06F8/42Syntactic analysis
    • G06F8/427Parsing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • G06F8/42Syntactic 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)

Abstract

本公开关于一种代码转换方法及装置,通过获取待处理代码后,将待处理代码解析为抽象语法树,通过确定抽象语法树中的链式取值代码,对链式取值代码添加存在判断代码,然后将添加存在判断代码的抽象语法树转换为指定脚本的代码。从而不但可以减少编程人员手动添加的工作量,并且通过存在判断而避免链式取值过程中取值不存在问题导致的报错。

Description

一种代码转换方法及装置
技术领域
本公开涉及信息技术领域,尤其涉及一种代码转换方法及装置。
背景技术
相关技术中,链式取值可以利用运算符进行的连续取值,例如,在某一条语句中对某一方的某个对象的某个属性进行取值,x.a.b.c。然而在使用链式取值时,常常会出现不存在,而导致报错。例如,通过链式取值获取有某一代码引出的多个代码的取值,而当使用链式取值时,由于某一其中的某一取值不存在,而会出现报错。
在相关技术中,为避免报错通常会通过添加存在判断时方式进行编码。例如在进行链式取值之前,先判断每一取值是否存在,从而避免由于该取值不存在导致的报错。然而,在编程人员手动添加存在判断时,由于往往所需添加的编码较长,从而导致所需添加的编码较多,增加编程人员的工作量。
发明内容
本公开提供一种代码转换方法及装置,以至少解决相关技术中增加编程人员的工作量的问题。本公开的技术方案如下:
根据本公开实施例的第一方面,提供一种代码转换方法,包括:
获取待处理代码,将待处理代码解析为抽象语法树;
确定抽象语法树中的链式取值代码;
对链式取值代码添加存在判断代码;
将添加存在判断代码的抽象语法树转换为指定脚本的代码。
可选的,在确定抽象语法树中的链式取值代码之后,上述方法还包括:
对链式取值代码添加第一标记;
对链式取值代码添加存在判断代码,包括:
对存在第一标记的链式取值代码添加存在判断代码。
可选的,在对存在第一标记的链式取值代码添加存在判断代码之后,上述方法还包括:
对添加存在判断代码后的链式取值代码添加第二标记。
可选的,对存在第一标记的链式取值代码添加存在判断代码,包括:
对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码。
可选的,在对链式取值代码添加存在判断代码之后,上述方法还包括:
对添加存在判断代码后的链式取值代码添加第二标记;
对链式取值代码添加存在判断代码,包括:
对不存在第二标记的链式取值代码添加存在判断代码。
可选的,将添加存在判断代码的抽象语法树转换为指定脚本的代码,包括:
对链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
可选的,将添加存在判断代码的抽象语法树转换为指定脚本的代码之后,方法还包括:
通过预设算法对指定脚本的代码进行编译,得到编译后的程序。
根据本公开实施例的第二方面,提供一种代码转换装置,包括:
代码获取模块,用于获取待处理代码,将待处理代码解析为抽象语法树;
代码确定模块,用于确定抽象语法树中的链式取值代码;
代码添加模块,用于对链式取值代码添加存在判断代码;
代码转换模块,用于将添加存在判断代码的抽象语法树转换为指定脚本的代码。
可选的,上述装置还包括:
第一标记模块,用于对链式取值代码添加第一标记;
代码添加模块,包括:
第一添加模块,用于对存在第一标记的链式取值代码添加存在判断代码。
可选的,上述装置还包括:
第二标记模块,用于对添加存在判断代码后的链式取值代码添加第二标记。
可选的,第一添加模块,包括:
第二添加子模块,用于对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码。
可选的,上述装置还包括:
第二判断模块,用于对添加存在判断代码后的链式取值代码添加第二标记;
代码添加模块,包括:
第二取值模块,用于对不存在第二标记的链式取值代码添加存在判断代码。
可选的,代码转换模块,包括:
函数转换子模块,用于对链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
可选的,上述装置还包括:
代码编译模块,用于通过预设算法对指定脚本的代码进行编译,得到编译后的程序。
根据本公开实施例的第三方面,提供一种电子设备,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,处理器被配置为执行指令,以实现上述任一代码转换方法。
根据本公开实施例的第四方面,提供一种存储介质,
当存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行上述任一代码转换方法。
根据本公开实施例的第五方面,提供一种计算机程序产品,当计算机程序产品被计算机执行时,使得计算机能够执行上述任一代码转换方法。
本公开的实施例提供的技术方案至少带来以下有益效果:通过获取待处理代码后,将待处理代码解析为抽象语法树抽象语法树,通过确定抽象语法树中的链式取值代码,对链式取值代码添加存在判断代码,然后将添加存在判断代码的抽象语法树转换为指定脚本的代码。从而不但可以减少编程人员手动添加的工作量,并且通过存在判断而避免链式取值过程中取值不存在问题导致的报错。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理,并不构成对本公开的不当限定。
图1是根据一示例性实施例示出的一种代码转换方法的一种流程图。
图2是根据一示例性实施例示出的一种代码转换的另一种流程图。
图3是根据一示例性实施例示出的一种代码转换装置的一种框图。
图4是根据一示例性实施例示出的一种代码转换装置的另一种框图。
图5是根据一示例性实施例示出的一种用于代码转换的装置500的框图。
图6是根据一示例性实施例示出的一种用于代码转换的装置600的框图。
具体实施方式
为了使本领域普通人员更好地理解本公开的技术方案,下面将结合附图,对本公开实施例中的技术方案进行清楚、完整地描述。
需要说明的是,本公开的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本公开的实施例能够以除了在这里图示或描述的那些以外的顺序实施。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
本公开实施例的代码转换方法针对的是智能终端设备中的程序,因此可以通过智能终端设备执行,具体的,该智能终端设备可以为电脑或服务器等。
图1是根据一示例性实施例示出的一种代码转换方法的一种流程图,如图1所示,代码转换方法用于应用于编译过程中,包括以下步骤:
在步骤S11中,获取待处理代码,将待处理代码解析为抽象语法树。
其中,本公开实施例的方法应用于编译流程,通过获取待处理代码,并将待处理代码解析为抽象语法树。其中,AST(AbstractSyntaxTree,抽象语法树)是源代码语法结构的一种抽象表示。它以树状的形式表现编程语言的语法结构,树上的每个节点都表示源代码中的一种结构。在一种可能的实施方式中,本申请针对JS(JavaScript,一种直译式脚本语言)中对象,而对于浏览器等在执行JS之前会把JS源码通过解析器转化为抽象语法树,再进一步转化为字节码甚至是机器码。
在步骤S12中,确定抽象语法树中的链式取值代码。
其中,链式取值为可以利用运算符进行的连续取值,例如在一条语句中出现两个或者两个以上相同的取值。其中,确定AST中的链式取值代码的方法可以使用多种类型的方法,例如,通过关键字查找的方式遍历上述AST确定确定AST中的链式取值代码,该确定方法非本发明保护的核心,此处不再赘述。
通过确定AST中的链式取值代码,可以针对该链式取值代码进行修改替换等操作,从而实现本申请实施中的添加存在判断代码的目的。
可选的,在确定抽象语法树中的链式取值代码之后,上述代码转换方法还包括:对链式取值代码添加第一标记;对链式取值代码添加存在判断代码,包括:对存在第一标记的链式取值代码添加存在判断代码。
其中,对链式取值代码添加第一标记,可以为多种类型的标记。例如,在AST中链式取值代码X,对上述对链式取值代码添加第一标记,可以为对X添加标记A,或*等方式,此处不再赘述。
通过对链式取值代码添加第一标记,可以便于对上述链式取值代码进行查找和替换。例如,对于代码X添加标记A后,则可以通过判断是否有标记A,确定是否应对该链式取值代码机型添加判断代码。
可选的,在对存在第一标记的链式取值代码添加存在判断代码之后,上述代码转换方法还包括:对添加存在判断代码后的链式取值代码添加第二标记。
可选的,对存在第一标记的链式取值代码添加存在判断代码,包括:对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码。
其中,通过添加第二标记,可以判断该链式取值代码是否已经添加了存在判断,从而避免再次添加存在判断代码。
在步骤S13中,对链式取值代码添加存在判断代码。
其中,对链式取值代码添加存在判断代码,可以为通过生成添加存在判断代码链式取值代码对原代码进行替换,或对链式取值代码直接进行添加存在判断代码。该判断代码用于表示判断所对应的代码是否存在,在一种可能的实施方式中,在代码中可以为对代码添加“?.”,例如,对于链式取值代码添加存在判断代码后为,var y=x?.a?.b?.c?.[0],此处不对上述判断代码进行限定。
通过对链式取值代码添加存在判断代码,可以对上述链式取值代码中的链式取值进行判断,从而可以避免链式取值不存在导致的报错。
可选的,在对链式取值代码添加存在判断代码之后,上述方法还包括:对添加存在判断代码后的链式取值代码添加第二标记;对链式取值代码添加存在判断代码,包括:对不存在第二标记的链式取值代码添加存在判断代码。
上述对添加存在判断代码后的链式取值代码添加第二标记,即不需通过添加第一标记,直接对添加存在判断代码后的链式取值代码添加第二标记,而后对不存在第二标记的链式取值代码添加存在判断代码。
在步骤S14中,将添加存在判断代码的抽象语法树转换为指定脚本的代码。
其中,将添加存在判断代码的抽象语法树转换为指定脚本的代码,可以为通过多种类型的方式,将上述AST转换为原待处理代码对应的脚本代码。该转换方式可以通过多种类型的方式,本申请对此不进行限定。
本公开实施例的方法应用于编译过程中,因此通过将添加存在判断代码的AST转换为可选的,将添加存在判断代码的抽象语法树转换为指定脚本的代码,包括:对链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
其中,预设转换函数可以为generator构造器,generator构造器为babel-generator构造器,可以将AST构造成真实代码。
可选的,上述方法还包括:通过预设算法对指定脚本的代码进行编译,得到编译后的程序。
可见,通过本公开实施例的代码转换方法,通过获取待处理代码后,将待处理代码解析为抽象语法树,通过确定抽象语法树中的链式取值代码,对链式取值代码添加存在判断代码,然后将添加存在判断代码的抽象语法树转换为指定脚本的代码。从而不但可以减少编程人员手动添加的工作量,并且通过存在判断而避免链式取值过程中取值不存在问题导致的报错。
图2是根据一示例性实施例示出的一种代码转换方法的另一种流程图,如图2所示,代码转换方法用于应用于编译过程中,包括以下步骤:
在步骤S11中,获取待处理代码,将待处理代码解析为抽象语法树。
其中,上述待处理代码可以为多种类型的代码,例如可以为JS中的对象。通过获取待处理代码,将待处理代码解析为抽象语法树AST,可以便于利用抽象语法树AST对其中的链式取值代码进行查找。
在步骤S12中,确定抽象语法树中的链式取值代码。
其中,确定AST中的链式取值代码,可以为确定多种类型的链式取值代码,例如,res.data.goods.list[0].price,本公开实施例不对此进行限定。由于链式取值代码常会出现由于不存在而导致报错,因此通过确定AST中的链式取值代码后,添加存在判断,可以避免由于取值不存在导致的报错。
在步骤S21中,对链式取值代码添加第一标记;
其中,对链式取值代码添加第一标记,可以为多种类型的标记。例如,在AST中链式取值代码X,对上述对链式取值代码添加第一标记,可以为对X添加原始标记A,或*等方式,此处不再赘述。
通过对链式取值代码添加第一标记,可以便于对上述链式取值代码进行查找和替换。例如,对于代码X添加标记A后,则可以通过判断是否有标记A,确定是否应对该链式取值代码机型添加判断代码。
在步骤S22中,对存在第一标记的链式取值代码添加存在判断代码。
其中,对存在第一标记的链式取值代码添加存在判断代码,上述判断代码可以为对代码添加“?.”,例如,对于链式取值代码添加存在判断代码后为,var y=x?.a?.b?.c?.[0],此处不对上述判断代码进行限定。例如,对于代码添加标记A后,通过判断标记A,对所需添加存在判断的链式取值存在判断代码,可以。
通过对存在第一标记的链式取值代码添加存在判断代码,可以避免由于链式取值代码不存在而导致报错。
在步骤S23中,对添加存在判断代码后的链式取值代码添加第二标记。
其中,对添加存在判断代码后的链式取值代码添加第二标记,可以为区别于上述第一标记的多种类型的标记。通过对添加存在判断代码后的链式取值代码添加第二标记,可以避免对上述添加存在判断代码后的链式取值代码再次添加存在判断代码。
通过对添加存在判断代码后的链式取值代码添加第二标记,可以判断该链式取值代码是否已经添加了存在判断,从而避免再次添加存在判断代码。
可选的,对存在第一标记的链式取值代码添加存在判断代码,包括:对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码。
其中,对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码,由于上述第一标记为对上述对链式取值代码添加第一标记,上述第二标记为对添加存在判断代码后的链式取值代码添加第二标记,因此对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码,即对所获取的单位添加存在判断代码的链式取值代码添加存在判断。
从通过对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码,可以避免对对所获的链式取值代码未添加存在判断,避免出现未添加的问题。
在步骤S24中,对链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
其中,预设转换函数可以为generator构造器,通过generator构造器进行转换,得到转换后的代码,可以将添加存在判断代码的AST转换为指定脚本的代码,可以便于后续的编译流程,避免对后续流程产生影响。
可选的,上述方法还包括:通过预设算法对指定脚本的代码进行编译,得到编译后的程序。
可见,通过本公开实施例的代码转换方法,通过获取待处理代码后,对链式取值代码添加第一标记,然后对存在第一标记的链式取值代码添加存在判断代码,对添加存在判断代码后的链式取值代码添加第二标记。从而不但可以减少编程人员手动添加的工作量,并且通过存在判断而避免链式取值过程中取值不存在问题导致的报错,同时可以通过第一标签和第二标签的判断,避免未添加存在判断代码和未添加的问题。
图3是根据一示例性实施例示出的一种代码转换装置的一种框图。参照图3,该装置包括代码获取模块121,代码确定模块122,代码添加模块123和代码转换模块124。
该代码获取模块121被配置为用于获取待处理代码,将待处理代码解析为抽象语法树AST。
该代码确定模块122被配置为用于确定抽象语法树中的链式取值代码。
该代码添加模块123被配置为用于对链式取值代码添加存在判断代码。
该代码转换模块124被配置为用于将添加存在判断代码的抽象语法树转换为指定脚本的代码。
可选的,上述代码转换装置还包括:
第一标记模块,用于对链式取值代码添加第一标记;
代码添加模块123,包括:
第一添加模块,用于对存在第一标记的链式取值代码添加存在判断代码。
可选的,上述代码转换装置还包括:
第二标记模块,用于对添加存在判断代码后的链式取值代码添加第二标记。
可选的,第一添加模块,包括:
第二添加子模块,用于对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码。
可选的,代码转换模块124,包括:
函数转换子模块,用于对链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
可选的,上述装置还包括:
第二判断模块,用于对添加存在判断代码后的链式取值代码添加第二标记;
代码添加模块,包括:
第二取值模块,用于对不存在第二标记的链式取值代码添加存在判断代码。
可选的,上述装置还包括:
代码编译模块,用于通过预设算法对指定脚本的代码进行编译,得到编译后的程序。
可见,通过本公开实施例的代码转换装置,通过获取待处理代码后,将待处理代码解析为抽象语法树抽象语法树,通过确定抽象语法树中的链式取值代码,对链式取值代码添加存在判断代码,然后将添加存在判断代码的抽象语法树转换为指定脚本的代码。从而不但可以减少编程人员手动添加的工作量,并且通过存在判断而避免链式取值过程中取值不存在问题导致的报错。
图4是根据一示例性实施例示出的一种代码转换装置的另一种框图。参照图4,该装置包括代码获取模块121,代码确定模块122,第一标记模块131,第一添加模块132和第二标记模块133,函数转换子模块134。
该代码获取模块121被配置为用于获取待处理代码,将待处理代码解析为抽象语法树AST。
该代码确定模块122被配置为用于确定抽象语法树中的链式取值代码。
该第一标记模块131被配置为用于对链式取值代码添加第一标记;
该第一添加模块132被配置为用于对存在第一标记的链式取值代码添加存在判断代码。
该第二标记模块133被配置为用于对添加存在判断代码后的链式取值代码添加第二标记。
该函数转换子模块134被配置为用于对链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
可选的,第一添加模块,包括:
第二添加子模块,用于对存在第一标记且不存在第二标记的链式取值代码添加存在判断代码。
可选的,上述装置还包括:
代码编译模块,用于通过预设算法对指定脚本的代码进行编译,得到编译后的程序。
可见,通过本公开实施例的代码转换装置,通过获取待处理代码后,对链式取值代码添加第一标记,然后对存在第一标记的链式取值代码添加存在判断代码,对添加存在判断代码后的链式取值代码添加第二标记。从而不但可以减少编程人员手动添加的工作量,并且通过存在判断而避免链式取值过程中取值不存在问题导致的报错,同时可以通过第一标签和第二标签的判断,避免未添加存在判断代码和未添加的问题。
图5是根据一示例性实施例示出的一种用于代码转换的装置500的框图。例如,装置500可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图5,装置500可以包括以下一个或多个组件:处理组件502,存储器504,电源组件506,多媒体组件508,音频组件510,输入/输出接口512,传感器组件514,以及通信组件516。
处理组件502通常控制装置500的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件502可以包括一个或多个处理器520来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件502可以包括一个或多个模块,便于处理组件502和其他组件之间的交互。例如,处理组件502可以包括多媒体模块,以方便多媒体组件508和处理组件502之间的交互。
存储器504被配置为存储各种类型的数据以支持在装置500的操作。这些数据的示例包括用于在装置500上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器504可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件506为装置500的各种组件提供电力。电源组件506可以包括电源管理系统,一个或多个电源,及其他与为装置500生成、管理和分配电力相关联的组件。
多媒体组件508包括在所述装置500和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件508包括一个前置摄像头和/或后置摄像头。当设备500处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件510被配置为输出和/或输入音频信号。例如,音频组件510包括一个麦克风(MIC),当装置500处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器504或经由通信组件516发送。在一些实施例中,音频组件510还包括一个扬声器,用于输出音频信号。
输入输出接口512为处理组件502和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件514包括一个或多个传感器,用于为装置500提供各个方面的状态评估。例如,传感器组件514可以检测到设备500的打开/关闭状态,组件的相对定位,例如所述组件为装置500的显示器和小键盘,传感器组件514还可以检测装置500或装置500一个组件的位置改变,用户与装置500接触的存在或不存在,装置500方位或加速/减速和装置500的温度变化。传感器组件514可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件514还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件514还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件516被配置为便于装置500和其他设备之间有线或无线方式的通信。装置500可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件516经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件516还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置500可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述代码转换方法。
在示例性实施例中,还提供了一种包括指令的存储介质,例如包括指令的存储器804,上述指令可由装置500的处理器520执行以完成上述方法。可选地,存储介质可以是非临时性计算机可读存储介质,例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
图6是根据一示例性实施例示出的一种用于代码转换的装置600的框图。例如,装置600可以被提供为一服务器。参照图6,装置600包括处理组件622,其进一步包括一个或多个处理器,以及由存储器632所代表的存储器资源,用于存储可由处理组件622的执行的指令,例如应用程序。存储器632中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件622被配置为执行指令,以执行上述代码转换方法。
装置600还可以包括一个电源组件626被配置为执行装置600的电源管理,一个有线或无线的网络接口650被配置为将装置600连接到网络,和一个输入输出接口658。装置600可以操作基于存储在存储器632的操作系统,例如Windows ServerTM,Mac OS XTM,UnixTM,LinuxTM,FreeBSDTM或类似。
根据本公开实施例还提供一种电子设备,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,处理器被配置为执行指令,以实现上述任一代码转换方法。
根据本公开实施例还提供一种计算机程序产品,当计算机程序产品被计算机执行时,使得计算机能够执行上述任一代码转换方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。

Claims (14)

1.一种代码转换方法,其特征在于,应用于编译过程中,包括:
获取待处理代码,将所述待处理代码解析为抽象语法树;
确定所述抽象语法树中的链式取值代码;
对所述链式取值代码添加存在判断代码;
将添加存在判断代码的抽象语法树转换为指定脚本的代码;
在所述对所述链式取值代码添加存在判断代码之后,所述方法还包括:
对添加存在判断代码后的链式取值代码添加第二标记;
所述对所述链式取值代码添加存在判断代码,包括:
对不存在所述第二标记的链式取值代码添加存在判断代码。
2.根据权利要求1所述的代码转换方法,其特征在于,在所述确定所述抽象语法树中的链式取值代码之后,所述方法还包括:
对所述链式取值代码添加第一标记;
所述对所述链式取值代码添加存在判断代码,包括:
对存在所述第一标记的链式取值代码添加存在判断代码。
3.根据权利要求2所述的代码转换方法,其特征在于,在所述对存在所述第一标记的链式取值代码添加存在判断代码之后,所述方法还包括:
对添加存在判断代码后的链式取值代码添加第二标记。
4.根据权利要求3所述的代码转换方法,其特征在于,所述对存在所述第一标记的链式取值代码添加存在判断代码,包括:
对存在所述第一标记且不存在所述第二标记的链式取值代码添加存在判断代码。
5.根据权利要求1所述的代码转换方法,其特征在于,所述将添加存在判断代码的抽象语法树转换为指定脚本的代码,包括:
对所述链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
6.根据权利要求1所述的代码转换方法,其特征在于,所述将添加存在判断代码的抽象语法树转换为指定脚本的代码之后,所述方法还包括:
通过预设算法对所述指定脚本的代码进行编译,得到编译后的程序。
7.一种代码转换装置,其特征在于,应用于编译过程中,包括:
代码获取模块,用于获取待处理代码,将所述待处理代码解析为抽象语法树;
代码确定模块,用于确定所述抽象语法树中的链式取值代码;
代码添加模块,用于对所述链式取值代码添加存在判断代码;
代码转换模块,用于将添加存在判断代码的抽象语法树转换为指定脚本的代码;
所述装置还包括:
第二判断模块,用于对添加存在判断代码后的链式取值代码添加第二标记;
所述代码添加模块,包括:
第二取值模块,用于对不存在所述第二标记的链式取值代码添加存在判断代码。
8.根据权利要求7所述的代码转换装置,其特征在于,所述装置还包括:
第一标记模块,用于对所述链式取值代码添加第一标记;
所述代码添加模块,包括:
第一添加模块,用于对存在所述第一标记的链式取值代码添加存在判断代码。
9.根据权利要求8所述的代码转换装置,其特征在于,所述装置还包括:
第二标记模块,用于对添加存在判断代码后的链式取值代码添加第二标记。
10.根据权利要求9所述的代码转换装置,其特征在于,所述第一添加模块,包括:
第二添加子模块,用于对存在所述第一标记且不存在所述第二标记的链式取值代码添加存在判断代码。
11.根据权利要求7所述的代码转换装置,其特征在于,所述代码转换模块,包括:
函数转换子模块,用于对所述链式取值代码添加存在判断代码,使用预设转换函数进行转换,得到指定脚本的代码。
12.根据权利要求7所述的代码转换装置,其特征在于,所述装置还包括:
代码编译模块,用于通过预设算法对所述指定脚本的代码进行编译,得到编译后的程序。
13.一种电子设备,其特征在于,包括:
处理器;
用于存储所述处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述指令,以实现如权利要求1至6中任一项所述的代码转换方法。
14.一种存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如权利要求1至6中任一项所述的代码转换方法。
CN201911025267.5A 2019-10-25 2019-10-25 一种代码转换方法及装置 Active CN112711420B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911025267.5A CN112711420B (zh) 2019-10-25 2019-10-25 一种代码转换方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911025267.5A CN112711420B (zh) 2019-10-25 2019-10-25 一种代码转换方法及装置

Publications (2)

Publication Number Publication Date
CN112711420A CN112711420A (zh) 2021-04-27
CN112711420B true CN112711420B (zh) 2024-03-01

Family

ID=75540833

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911025267.5A Active CN112711420B (zh) 2019-10-25 2019-10-25 一种代码转换方法及装置

Country Status (1)

Country Link
CN (1) CN112711420B (zh)

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109614772A (zh) * 2018-11-20 2019-04-12 江苏通付盾信息安全技术有限公司 基于应用安装包文件的代码转换方法及装置
CN109960497A (zh) * 2017-12-26 2019-07-02 北京高德云图科技有限公司 一种脚本文件间的调用方法及装置
CN110287429A (zh) * 2019-06-28 2019-09-27 百度在线网络技术(北京)有限公司 数据解析方法、装置、设备及存储介质

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10140105B2 (en) * 2016-03-10 2018-11-27 Wowza Media Systems, LLC Converting source code

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109960497A (zh) * 2017-12-26 2019-07-02 北京高德云图科技有限公司 一种脚本文件间的调用方法及装置
CN109614772A (zh) * 2018-11-20 2019-04-12 江苏通付盾信息安全技术有限公司 基于应用安装包文件的代码转换方法及装置
CN110287429A (zh) * 2019-06-28 2019-09-27 百度在线网络技术(北京)有限公司 数据解析方法、装置、设备及存储介质

Also Published As

Publication number Publication date
CN112711420A (zh) 2021-04-27

Similar Documents

Publication Publication Date Title
CN106569800B (zh) 前端界面生成方法及装置
CN109032606B (zh) 原生应用程序的编译处理方法、装置及终端
CN107423106B (zh) 支持多框架语法的方法和装置
CN111274131A (zh) 接口测试方法、装置、电子设备及存储介质
CN111538502A (zh) 安装包的处理方法、装置、电子设备及存储介质
CN115185717A (zh) 接口调用方法、装置、电子设备和存储介质
CN113157256B (zh) 接口代码的生成方法、装置、电子设备、存储介质及产品
CN111580824B (zh) 程序优化方法、装置及存储介质
CN111767058A (zh) 程序编译方法及装置、电子设备和存储介质
CN112114814A (zh) 编译文件确定方法及装置、应用程序生成方法及装置
CN111209195A (zh) 一种生成测试用例的方法及装置
CN112711420B (zh) 一种代码转换方法及装置
CN111667827B (zh) 应用程序的语音控制方法、装置及存储介质
CN112860625B (zh) 数据获取方法、数据存储方法、装置、设备及存储介质
CN112333233B (zh) 事件信息的上报方法、装置、电子设备及存储介质
CN111131000B (zh) 一种信息传输方法、装置、服务器、终端
CN107193622B (zh) 代码编译的处理方法、装置及终端
CN111597106A (zh) 一种埋点管理方法及装置
CN113420531B (zh) 一种代码文本的转换方法、装置及存储介质
CN111538486B (zh) 布局文件嵌套层数筛查方法、装置及电子设备
CN112182027B (zh) 信息查询方法、装置、电子设备及存储介质
WO2023245344A1 (zh) 一种应用程序处理方法、装置、终端及存储介质
CN113342355B (zh) 一种代码编译方法、装置、电子设备及存储介质
CN114756319A (zh) 小程序页面显示方法、装置、设备及存储介质
CN110084065B (zh) 数据脱敏方法及装置

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