标识符的作用域规则
标识符是模块、变量、端口、实例、函数、任务、块结构等对象的名称,用于唯一地标识该对象。一个标识符的作用域是指Verilog描述中,该标识可以被识别的范围,作用域规则定义了这个范围。
Verilog可以在四种实体中定义标识符:即模块、任务、函数和有名块。每个实体定义的标识符的局部作用域从它的定义位置开始到相应实体结束。对于这四种实体,其标识符范围为:
|
标识符引用的两种方式:
①超前引用:定义前就可引用,模块、任务、函数和有名块的标识符在定义前就可使用,如模块定义前就实例化一个模块、定义前调用一个任务或函数、终止一个有名块等;
②非超前引用:定义后方可引用,如寄存器,线网等变量不能超前引用;因此通常在定义模块等实体的局部作用域的开始处定义它们。
在一个作用域中不能定义相同标识符,即
①在同一个实体内定义两个相同名字的变量;(同一模块、任务、函数和有名块);
②变量名与任务有相同的名字。
Verilog将所有标识符组织成树的结构,树的根节点是没有被实例化的模块名(即最高层模块)。