5、符号表与索引生成器:从文本索引到C语言交叉引用

符号表与索引生成器:从文本索引到C语言交叉引用

1. 符号表与索引生成器概述

在许多flex或bison程序中,符号表是一个关键组件,用于跟踪输入中使用的名称。我们将从一个简单的索引生成程序开始,该程序会列出输入中每个单词出现的行号,随后将其修改为一个C语言交叉引用程序。

1.1 索引生成器的符号表管理

索引生成器的符号表主要用于跟踪每个单词及其所在的文件和行号。以下是索引生成器的声明部分示例:

/* fb2-4 text concordance */
%option noyywrap nodefault yylineno case-insensitive
/* the symbol table */
%{
  struct symbol {               /* a word */
    char *name;
    struct ref *reflist;
  };
  struct ref {
    struct ref *next;
    char *filename;
    int flags;
    int lineno;
  };
  /* simple symtab of fixed size */
  #define NHASH 9997
  struct symbol symtab[NHASH];
  struct symbol *lookup(char*);
  void addref(int, char*, char*,int);
  char *curfilename;            /* name of current input file */
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值