分析源代码中的每个类的成员函数及其作用,分析源代码中的不同类的调用关系package symbols; import java.util.*; import lexer.*; import inter.*; public class Env { private Hashtable table; protected Env prev; public Env(Env n) { table = new Hashtable(); prev = n; } public void put(Token w, Id i) { table.put(w, i); } public Id get(Token w) { for( Env e = this; e != null; e = e.prev ) { Id found = (Id)(e.table.get(w)); if( found != null ) return found; } return null; } }
时间: 2023-05-31 17:01:28 浏览: 139
这个类定义了一个符号表,用于存储标识符和对应的符号。它主要有以下几个成员函数:
1. Env(Env n):构造函数,创建一个新的符号表,并将其前一个符号表设置为n。
2. put(Token w, Id i):将标识符i和对应的符号w插入到符号表中。
3. get(Token w):从符号表中查找并返回与符号w对应的标识符。它首先从当前符号表开始查找,如果找不到则继续在前一个符号表中查找,直到找到或遍历完所有符号表。
在编译器中,符号表是一个非常重要的数据结构,用于存储标识符和对应的符号,在语义分析和代码生成中都会用到。Env类提供了查找和插入标识符的方法,使得编译器能够方便地管理符号表。在编译器中,通常会创建多个符号表,用于存储不同作用域中的标识符,Env类的prev成员变量可以用于链接不同符号表之间的关系。
相关问题
分析源代码中的每个类的成员函数及其作用,分析源代码中的不同类的调用关系package inter; import lexer.*; import symbols.*; public class Temp extends Expr { static int count = 0; int number = 0; public Temp(Type p) { super(Word.temp, p); number = ++count; } public String toString() { return "t" + number; } }
该代码中只有一个类:Temp。
该类的成员函数及其作用:
1. 构造函数public Temp(Type p):用于创建一个新的Temp对象,该对象的类型为Type p,同时给该对象的number成员赋值为count的值。
2. toString()函数:返回该对象的字符串表示,格式为"t"加上该对象的number成员的值。
该类的调用关系:该类没有调用其他类的函数,也没有被其他类调用。
分析源代码中的每个类的成员函数及其作用,分析源代码中的不同类的调用关系package symbols; import lexer.*; public class Array extends Type { public Type of; // array *of* type public int size = 1; // number of elements public Array(int sz, Type p) { super("[]", Tag.INDEX, sz*p.width); size = sz; of = p; } public String toString() { return "[" + size + "] " + of.toString(); } }
该源代码中只有一个类:Array。该类继承了Type类,并添加了两个成员变量:of和size。of表示数组的元素类型,size表示数组的大小。
该类有一个构造函数,接受两个参数:数组的大小和元素类型。构造函数调用父类Type的构造函数,并使用Tag.INDEX作为类型标记。同时,计算数组的总大小,即元素类型的大小乘以数组大小,并将结果传递给父类构造函数。
该类还有一个toString方法,用于将数组转换为字符串。该方法返回一个字符串,包含数组的大小和元素类型。
该类没有其他成员函数。
由于该类是最基础的数据类型之一,因此在其他类中经常会使用该类的实例。例如,在语法分析器中,当遇到数组类型的变量时,会创建一个Array实例来表示该变量的类型。在生成目标代码时,也需要使用该类的实例来计算数组的地址和偏移量。
阅读全文