[发明专利]生成代码文件的语法树的方法、装置及电子设备在审

专利信息
申请号: 201811644381.1 申请日: 2018-12-29
公开(公告)号: CN111381828A 公开(公告)日: 2020-07-07
发明(设计)人: 冯刚 申请(专利权)人: 北京奇虎科技有限公司
主分类号: G06F8/41 分类号: G06F8/41
代理公司: 北京市立方律师事务所 11330 代理人: 张筱宁
地址: 100088 北京市西城区新*** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 生成 代码 文件 语法 方法 装置 电子设备
【说明书】:

本申请涉及计算机软件开发技术领域,公开了一种生成代码文件的语法树的方法、装置及电子设备,其中,生成代码文件的语法树的方法包括:在接收到预定编程语言的待解析代码文件时,通过词法解析模块对待解析代码文件中的各个词法符号进行解析并生成相应的线性链表;接着基于第一查找表和第二查找表,依次对线性链表中的各个词法符号进行分析,生成待解析代码文件的语法树,第一查找表和第二查找表是基于对预定编程语言的文法进行分析生成的。本申请实施例的方法,使得可以通过语法树对编写完成的代码文件进行静态分析,从而准确、高效地对编写完成的代码文件中的语法错误、编写错误等进行检查及纠正,极大节省程序开发人员的时间、精力等。

技术领域

本申请涉及计算机软件开发技术领域,具体而言,本申请涉及一种生成代码文件的语法树的方法、装置及电子设备。

背景技术

在当前的计算机领域,C/C++/JAVA等高级编程语言对应的编译器开发技术越来越成熟,应用高级语言编译器能够实现将程序语言转化为机器语言的操作。但是,目前的编译器并不能逐一对代码文件中存在的代码编写错误进行全面、详尽分析,也无法准确对代码文件中存在的代码编写错误进行提示或纠正。因此,在对代码文件进行编译之前,需要程序开发人员手动检查代码文件中存在的错误。

然而,本申请的发明人在具体实施过程中发现:当代码文件中的代码量很大时,将会给程序开发人员造成极大工作量,不仅导致程序开发人员花费大量时间、精力等,检查代码文件中存在的错误,而且检查效率极低。同时,本申请的发明人发现:通过生成代码文件的语法树(syntaxtree),能够自动实现代码文件中语法错误、编写错误等的检查及纠正,极大提高检查效率,基于此本申请的发明人提供了一种生成代码文件的语法的方法、装置及电子设备。

发明内容

本申请的目的旨在至少能解决上述的技术缺陷之一,特提出以下技术方案:

第一方面,提供了一种生成代码文件的语法树的方法,包括:

在接收到预定编程语言的待解析代码文件时,通过词法解析模块对待解析代码文件中的各个词法符号进行解析并生成相应的线性链表;

基于第一查找表和第二查找表,依次对线性链表中的各个词法符号进行分析,生成待解析代码文件的语法树,第一查找表和第二查找表是基于对预定编程语言的文法进行分析生成的。

具体地,对预定编程语言的文法进行分析生成第一查找表和第二查找表的方式,包括:

确定预定编程语言中各种词法符号各自对应的类别和次序;

对文法符号进行划分,得到终结符号和非终结符号,文法符号包括各种词法符号及各种词法符号各自对应的类别,词法符号属于终结符号,类别属于非终结符号,非终结符号表示预定编程语言的层次结构;

依据各种词法符号分别对应的次序,确定各种词法符号分别归属的非终结符;

依据预生成的预定编程语言的状态以及终结符号,生成第一查找表,并依据预生成的预定编程语言的状态以及非终结符号,生成第二查找表。

进一步地,文法包括开始符号和产生式列表;

开始符号为预定义的非终结符号,产生式列表中的任一产生式表征终结符和非终结符之间的关系。

进一步地,任一产生式包括左部与右部,左部为右部归属的非终结符,右部为终结符的序列和/或非终结符的序列。

进一步地,左部的非终结符对应语法树中的结点,右部中的任一终结符或任一非终结符为结点的子结点。

进一步地,依次对线性链表中的各个词法符号进行分析,包括:

当线性链表中当前的词法符号为表示作用域开始的词法符号时,在作用域栈的栈顶创建相应的栈顶作用域,并将表示作用域开始的词法符号之后的词法符号写入栈顶作用域;以及,

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京奇虎科技有限公司,未经北京奇虎科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201811644381.1/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top